mirror of
https://github.com/langgenius/dify.git
synced 2024-11-16 03:32:23 +08:00
1f87676d52
Some checks are pending
Build and Push API & Web / build (api, DIFY_API_IMAGE_NAME, linux/amd64, build-api-amd64) (push) Waiting to run
Build and Push API & Web / build (api, DIFY_API_IMAGE_NAME, linux/arm64, build-api-arm64) (push) Waiting to run
Build and Push API & Web / build (web, DIFY_WEB_IMAGE_NAME, linux/amd64, build-web-amd64) (push) Waiting to run
Build and Push API & Web / build (web, DIFY_WEB_IMAGE_NAME, linux/arm64, build-web-arm64) (push) Waiting to run
Build and Push API & Web / create-manifest (api, DIFY_API_IMAGE_NAME, merge-api-images) (push) Blocked by required conditions
Build and Push API & Web / create-manifest (web, DIFY_WEB_IMAGE_NAME, merge-web-images) (push) Blocked by required conditions
Co-authored-by: Garfield Dai <dai.hai@foxmail.com>
58 lines
1.6 KiB
TypeScript
58 lines
1.6 KiB
TypeScript
import { escape } from 'lodash-es'
|
|
|
|
export const sleep = (ms: number) => {
|
|
return new Promise(resolve => setTimeout(resolve, ms))
|
|
}
|
|
|
|
export async function asyncRunSafe<T = any>(fn: Promise<T>): Promise<[Error] | [null, T]> {
|
|
try {
|
|
return [null, await fn]
|
|
}
|
|
catch (e: any) {
|
|
return [e || new Error('unknown error')]
|
|
}
|
|
}
|
|
|
|
export const getTextWidthWithCanvas = (text: string, font?: string) => {
|
|
const canvas = document.createElement('canvas')
|
|
const ctx = canvas.getContext('2d')
|
|
if (ctx) {
|
|
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"'
|
|
return Number(ctx.measureText(text).width.toFixed(2))
|
|
}
|
|
return 0
|
|
}
|
|
|
|
const chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ-_'
|
|
|
|
export function randomString(length: number) {
|
|
let result = ''
|
|
for (let i = length; i > 0; --i) result += chars[Math.floor(Math.random() * chars.length)]
|
|
return result
|
|
}
|
|
|
|
export const getPurifyHref = (href: string) => {
|
|
if (!href)
|
|
return ''
|
|
|
|
return escape(href)
|
|
}
|
|
|
|
export async function fetchWithRetry<T = any>(fn: Promise<T>, retries = 3): Promise<[Error] | [null, T]> {
|
|
const [error, res] = await asyncRunSafe(fn)
|
|
if (error) {
|
|
if (retries > 0) {
|
|
const res = await fetchWithRetry(fn, retries - 1)
|
|
return res
|
|
}
|
|
else {
|
|
if (error instanceof Error)
|
|
return [error]
|
|
return [new Error('unknown error')]
|
|
}
|
|
}
|
|
else {
|
|
return [null, res]
|
|
}
|
|
}
|