localize.js 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. import { buildLocalizeFn } from "../../_lib/buildLocalizeFn.js";
  2. const eraValues = {
  3. narrow: ["BC", "AC"],
  4. abbreviated: ["きげんぜん", "せいれき"],
  5. wide: ["きげんぜん", "せいれき"],
  6. };
  7. const quarterValues = {
  8. narrow: ["1", "2", "3", "4"],
  9. abbreviated: ["Q1", "Q2", "Q3", "Q4"],
  10. wide: ["だい1しはんき", "だい2しはんき", "だい3しはんき", "だい4しはんき"],
  11. };
  12. const monthValues = {
  13. narrow: ["1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12"],
  14. abbreviated: [
  15. "1がつ",
  16. "2がつ",
  17. "3がつ",
  18. "4がつ",
  19. "5がつ",
  20. "6がつ",
  21. "7がつ",
  22. "8がつ",
  23. "9がつ",
  24. "10がつ",
  25. "11がつ",
  26. "12がつ",
  27. ],
  28. wide: [
  29. "1がつ",
  30. "2がつ",
  31. "3がつ",
  32. "4がつ",
  33. "5がつ",
  34. "6がつ",
  35. "7がつ",
  36. "8がつ",
  37. "9がつ",
  38. "10がつ",
  39. "11がつ",
  40. "12がつ",
  41. ],
  42. };
  43. const dayValues = {
  44. narrow: ["にち", "げつ", "か", "すい", "もく", "きん", "ど"],
  45. short: ["にち", "げつ", "か", "すい", "もく", "きん", "ど"],
  46. abbreviated: ["にち", "げつ", "か", "すい", "もく", "きん", "ど"],
  47. wide: [
  48. "にちようび",
  49. "げつようび",
  50. "かようび",
  51. "すいようび",
  52. "もくようび",
  53. "きんようび",
  54. "どようび",
  55. ],
  56. };
  57. const dayPeriodValues = {
  58. narrow: {
  59. am: "ごぜん",
  60. pm: "ごご",
  61. midnight: "しんや",
  62. noon: "しょうご",
  63. morning: "あさ",
  64. afternoon: "ごご",
  65. evening: "よる",
  66. night: "しんや",
  67. },
  68. abbreviated: {
  69. am: "ごぜん",
  70. pm: "ごご",
  71. midnight: "しんや",
  72. noon: "しょうご",
  73. morning: "あさ",
  74. afternoon: "ごご",
  75. evening: "よる",
  76. night: "しんや",
  77. },
  78. wide: {
  79. am: "ごぜん",
  80. pm: "ごご",
  81. midnight: "しんや",
  82. noon: "しょうご",
  83. morning: "あさ",
  84. afternoon: "ごご",
  85. evening: "よる",
  86. night: "しんや",
  87. },
  88. };
  89. const formattingDayPeriodValues = {
  90. narrow: {
  91. am: "ごぜん",
  92. pm: "ごご",
  93. midnight: "しんや",
  94. noon: "しょうご",
  95. morning: "あさ",
  96. afternoon: "ごご",
  97. evening: "よる",
  98. night: "しんや",
  99. },
  100. abbreviated: {
  101. am: "ごぜん",
  102. pm: "ごご",
  103. midnight: "しんや",
  104. noon: "しょうご",
  105. morning: "あさ",
  106. afternoon: "ごご",
  107. evening: "よる",
  108. night: "しんや",
  109. },
  110. wide: {
  111. am: "ごぜん",
  112. pm: "ごご",
  113. midnight: "しんや",
  114. noon: "しょうご",
  115. morning: "あさ",
  116. afternoon: "ごご",
  117. evening: "よる",
  118. night: "しんや",
  119. },
  120. };
  121. const ordinalNumber = (dirtyNumber, options) => {
  122. const number = Number(dirtyNumber);
  123. const unit = String(options?.unit);
  124. switch (unit) {
  125. case "year":
  126. return `${number}ねん`;
  127. case "quarter":
  128. return `だい${number}しはんき`;
  129. case "month":
  130. return `${number}がつ`;
  131. case "week":
  132. return `だい${number}しゅう`;
  133. case "date":
  134. return `${number}にち`;
  135. case "hour":
  136. return `${number}じ`;
  137. case "minute":
  138. return `${number}ふん`;
  139. case "second":
  140. return `${number}びょう`;
  141. default:
  142. return `${number}`;
  143. }
  144. };
  145. export const localize = {
  146. ordinalNumber: ordinalNumber,
  147. era: buildLocalizeFn({
  148. values: eraValues,
  149. defaultWidth: "wide",
  150. }),
  151. quarter: buildLocalizeFn({
  152. values: quarterValues,
  153. defaultWidth: "wide",
  154. argumentCallback: (quarter) => Number(quarter) - 1,
  155. }),
  156. month: buildLocalizeFn({
  157. values: monthValues,
  158. defaultWidth: "wide",
  159. }),
  160. day: buildLocalizeFn({
  161. values: dayValues,
  162. defaultWidth: "wide",
  163. }),
  164. dayPeriod: buildLocalizeFn({
  165. values: dayPeriodValues,
  166. defaultWidth: "wide",
  167. formattingValues: formattingDayPeriodValues,
  168. defaultFormattingWidth: "wide",
  169. }),
  170. };