| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 | import { MAX_VAR_KEY_LENGHT, VAR_ITEM_TEMPLATE, getMaxVarNameLength } from '@/config'import { CONTEXT_PLACEHOLDER_TEXT, HISTORY_PLACEHOLDER_TEXT, PRE_PROMPT_PLACEHOLDER_TEXT, QUERY_PLACEHOLDER_TEXT } from '@/app/components/base/prompt-editor/constants'const otherAllowedRegex = /^[a-zA-Z0-9_]+$/export const getNewVar = (key: string) => {  return {    ...VAR_ITEM_TEMPLATE,    key,    name: key.slice(0, getMaxVarNameLength(key)),  }}const checkKey = (key: string, canBeEmpty?: boolean) => {  if (key.length === 0 && !canBeEmpty)    return 'canNoBeEmpty'  if (canBeEmpty && key === '')    return true  if (key.length > MAX_VAR_KEY_LENGHT)    return 'tooLong'  if (otherAllowedRegex.test(key)) {    if (/[0-9]/.test(key[0]))      return 'notStartWithNumber'    return true  }  return 'notValid'}export const checkKeys = (keys: string[], canBeEmpty?: boolean) => {  let isValid = true  let errorKey = ''  let errorMessageKey = ''  keys.forEach((key) => {    if (!isValid)      return    const res = checkKey(key, canBeEmpty)    if (res !== true) {      isValid = false      errorKey = key      errorMessageKey = res    }  })  return { isValid, errorKey, errorMessageKey }}const varRegex = /\{\{([a-zA-Z_][a-zA-Z0-9_]*)\}\}/gexport const getVars = (value: string) => {  const keys = value.match(varRegex)?.filter((item) => {    return ![CONTEXT_PLACEHOLDER_TEXT, HISTORY_PLACEHOLDER_TEXT, QUERY_PLACEHOLDER_TEXT, PRE_PROMPT_PLACEHOLDER_TEXT].includes(item)  }).map((item) => {    return item.replace('{{', '').replace('}}', '')  }).filter(key => key.length <= MAX_VAR_KEY_LENGHT) || []  const keyObj: Record<string, boolean> = {}  // remove duplicate keys  const res: string[] = []  keys.forEach((key) => {    if (keyObj[key])      return    keyObj[key] = true    res.push(key)  })  return res}
 |