index.ts 1.1 KB

123456789101112131415161718192021222324252627282930313233
  1. export const sleep = (ms: number) => {
  2. return new Promise(resolve => setTimeout(resolve, ms))
  3. }
  4. export async function asyncRunSafe<T = any>(fn: Promise<T>): Promise<[Error] | [null, T]> {
  5. try {
  6. return [null, await fn]
  7. }
  8. catch (e) {
  9. if (e instanceof Error)
  10. return [e]
  11. return [new Error('unknown error')]
  12. }
  13. }
  14. export const getTextWidthWithCanvas = (text: string, font?: string) => {
  15. const canvas = document.createElement('canvas')
  16. const ctx = canvas.getContext('2d')
  17. if (ctx) {
  18. ctx.font = font ?? '12px Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"'
  19. return Number(ctx.measureText(text).width.toFixed(2))
  20. }
  21. return 0
  22. }
  23. const chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ-_'
  24. export function randomString(length: number) {
  25. let result = ''
  26. for (let i = length; i > 0; --i) result += chars[Math.floor(Math.random() * chars.length)]
  27. return result
  28. }