ko.js 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. import * as util from "../core/util.js";
  2. const Sizable = {
  3. string: { unit: "문자", verb: "to have" },
  4. file: { unit: "바이트", verb: "to have" },
  5. array: { unit: "개", verb: "to have" },
  6. set: { unit: "개", verb: "to have" },
  7. };
  8. function getSizing(origin) {
  9. return Sizable[origin] ?? null;
  10. }
  11. export const parsedType = (data) => {
  12. const t = typeof data;
  13. switch (t) {
  14. case "number": {
  15. return Number.isNaN(data) ? "NaN" : "number";
  16. }
  17. case "object": {
  18. if (Array.isArray(data)) {
  19. return "array";
  20. }
  21. if (data === null) {
  22. return "null";
  23. }
  24. if (Object.getPrototypeOf(data) !== Object.prototype && data.constructor) {
  25. return data.constructor.name;
  26. }
  27. }
  28. }
  29. return t;
  30. };
  31. const Nouns = {
  32. regex: "입력",
  33. email: "이메일 주소",
  34. url: "URL",
  35. emoji: "이모지",
  36. uuid: "UUID",
  37. uuidv4: "UUIDv4",
  38. uuidv6: "UUIDv6",
  39. nanoid: "nanoid",
  40. guid: "GUID",
  41. cuid: "cuid",
  42. cuid2: "cuid2",
  43. ulid: "ULID",
  44. xid: "XID",
  45. ksuid: "KSUID",
  46. datetime: "ISO 날짜시간",
  47. date: "ISO 날짜",
  48. time: "ISO 시간",
  49. duration: "ISO 기간",
  50. ipv4: "IPv4 주소",
  51. ipv6: "IPv6 주소",
  52. cidrv4: "IPv4 범위",
  53. cidrv6: "IPv6 범위",
  54. base64: "base64 인코딩 문자열",
  55. base64url: "base64url 인코딩 문자열",
  56. json_string: "JSON 문자열",
  57. e164: "E.164 번호",
  58. jwt: "JWT",
  59. template_literal: "입력",
  60. };
  61. const error = (issue) => {
  62. switch (issue.code) {
  63. case "invalid_type":
  64. return `잘못된 입력: 예상 타입은 ${issue.expected}, 받은 타입은 ${parsedType(issue.input)}입니다`;
  65. case "invalid_value":
  66. if (issue.values.length === 1)
  67. return `잘못된 입력: 값은 ${util.stringifyPrimitive(issue.values[0])} 이어야 합니다`;
  68. return `잘못된 옵션: ${util.joinValues(issue.values, "또는 ")} 중 하나여야 합니다`;
  69. case "too_big": {
  70. const adj = issue.inclusive ? "이하" : "미만";
  71. const suffix = adj === "미만" ? "이어야 합니다" : "여야 합니다";
  72. const sizing = getSizing(issue.origin);
  73. const unit = sizing?.unit ?? "요소";
  74. if (sizing)
  75. return `${issue.origin ?? "값"}이 너무 큽니다: ${issue.maximum.toString()}${unit} ${adj}${suffix}`;
  76. return `${issue.origin ?? "값"}이 너무 큽니다: ${issue.maximum.toString()} ${adj}${suffix}`;
  77. }
  78. case "too_small": {
  79. const adj = issue.inclusive ? "이상" : "초과";
  80. const suffix = adj === "이상" ? "이어야 합니다" : "여야 합니다";
  81. const sizing = getSizing(issue.origin);
  82. const unit = sizing?.unit ?? "요소";
  83. if (sizing) {
  84. return `${issue.origin ?? "값"}이 너무 작습니다: ${issue.minimum.toString()}${unit} ${adj}${suffix}`;
  85. }
  86. return `${issue.origin ?? "값"}이 너무 작습니다: ${issue.minimum.toString()} ${adj}${suffix}`;
  87. }
  88. case "invalid_format": {
  89. const _issue = issue;
  90. if (_issue.format === "starts_with") {
  91. return `잘못된 문자열: "${_issue.prefix}"(으)로 시작해야 합니다`;
  92. }
  93. if (_issue.format === "ends_with")
  94. return `잘못된 문자열: "${_issue.suffix}"(으)로 끝나야 합니다`;
  95. if (_issue.format === "includes")
  96. return `잘못된 문자열: "${_issue.includes}"을(를) 포함해야 합니다`;
  97. if (_issue.format === "regex")
  98. return `잘못된 문자열: 정규식 ${_issue.pattern} 패턴과 일치해야 합니다`;
  99. return `잘못된 ${Nouns[_issue.format] ?? issue.format}`;
  100. }
  101. case "not_multiple_of":
  102. return `잘못된 숫자: ${issue.divisor}의 배수여야 합니다`;
  103. case "unrecognized_keys":
  104. return `인식할 수 없는 키: ${util.joinValues(issue.keys, ", ")}`;
  105. case "invalid_key":
  106. return `잘못된 키: ${issue.origin}`;
  107. case "invalid_union":
  108. return `잘못된 입력`;
  109. case "invalid_element":
  110. return `잘못된 값: ${issue.origin}`;
  111. default:
  112. return `잘못된 입력`;
  113. }
  114. };
  115. export { error };
  116. export default function () {
  117. return {
  118. localeError: error,
  119. };
  120. }