ko.js 5.7 KB

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