localize.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. import { buildLocalizeFn } from "../../_lib/buildLocalizeFn.js";
  2. const eraValues = {
  3. narrow: ["ق", "ب"],
  4. abbreviated: ["ق.م.", "ب.م."],
  5. wide: ["قبل از میلاد", "بعد از میلاد"],
  6. };
  7. const quarterValues = {
  8. narrow: ["1", "2", "3", "4"],
  9. abbreviated: ["س‌م1", "س‌م2", "س‌م3", "س‌م4"],
  10. wide: ["سه‌ماهه 1", "سه‌ماهه 2", "سه‌ماهه 3", "سه‌ماهه 4"],
  11. };
  12. // Note: in English, the names of days of the week and months are capitalized.
  13. // If you are making a new locale based on this one, check if the same is true for the language you're working on.
  14. // Generally, formatted dates should look like they are in the middle of a sentence,
  15. // e.g. in Spanish language the weekdays and months should be in the lowercase.
  16. const monthValues = {
  17. narrow: ["ژ", "ف", "م", "آ", "م", "ج", "ج", "آ", "س", "ا", "ن", "د"],
  18. abbreviated: [
  19. "ژانـ",
  20. "فور",
  21. "مارس",
  22. "آپر",
  23. "می",
  24. "جون",
  25. "جولـ",
  26. "آگو",
  27. "سپتـ",
  28. "اکتـ",
  29. "نوامـ",
  30. "دسامـ",
  31. ],
  32. wide: [
  33. "ژانویه",
  34. "فوریه",
  35. "مارس",
  36. "آپریل",
  37. "می",
  38. "جون",
  39. "جولای",
  40. "آگوست",
  41. "سپتامبر",
  42. "اکتبر",
  43. "نوامبر",
  44. "دسامبر",
  45. ],
  46. };
  47. const dayValues = {
  48. narrow: ["ی", "د", "س", "چ", "پ", "ج", "ش"],
  49. short: ["1ش", "2ش", "3ش", "4ش", "5ش", "ج", "ش"],
  50. abbreviated: [
  51. "یکشنبه",
  52. "دوشنبه",
  53. "سه‌شنبه",
  54. "چهارشنبه",
  55. "پنجشنبه",
  56. "جمعه",
  57. "شنبه",
  58. ],
  59. wide: ["یکشنبه", "دوشنبه", "سه‌شنبه", "چهارشنبه", "پنجشنبه", "جمعه", "شنبه"],
  60. };
  61. const dayPeriodValues = {
  62. narrow: {
  63. am: "ق",
  64. pm: "ب",
  65. midnight: "ن",
  66. noon: "ظ",
  67. morning: "ص",
  68. afternoon: "ب.ظ.",
  69. evening: "ع",
  70. night: "ش",
  71. },
  72. abbreviated: {
  73. am: "ق.ظ.",
  74. pm: "ب.ظ.",
  75. midnight: "نیمه‌شب",
  76. noon: "ظهر",
  77. morning: "صبح",
  78. afternoon: "بعدازظهر",
  79. evening: "عصر",
  80. night: "شب",
  81. },
  82. wide: {
  83. am: "قبل‌ازظهر",
  84. pm: "بعدازظهر",
  85. midnight: "نیمه‌شب",
  86. noon: "ظهر",
  87. morning: "صبح",
  88. afternoon: "بعدازظهر",
  89. evening: "عصر",
  90. night: "شب",
  91. },
  92. };
  93. const formattingDayPeriodValues = {
  94. narrow: {
  95. am: "ق",
  96. pm: "ب",
  97. midnight: "ن",
  98. noon: "ظ",
  99. morning: "ص",
  100. afternoon: "ب.ظ.",
  101. evening: "ع",
  102. night: "ش",
  103. },
  104. abbreviated: {
  105. am: "ق.ظ.",
  106. pm: "ب.ظ.",
  107. midnight: "نیمه‌شب",
  108. noon: "ظهر",
  109. morning: "صبح",
  110. afternoon: "بعدازظهر",
  111. evening: "عصر",
  112. night: "شب",
  113. },
  114. wide: {
  115. am: "قبل‌ازظهر",
  116. pm: "بعدازظهر",
  117. midnight: "نیمه‌شب",
  118. noon: "ظهر",
  119. morning: "صبح",
  120. afternoon: "بعدازظهر",
  121. evening: "عصر",
  122. night: "شب",
  123. },
  124. };
  125. const ordinalNumber = (dirtyNumber, _options) => {
  126. return String(dirtyNumber);
  127. };
  128. export const localize = {
  129. ordinalNumber,
  130. era: buildLocalizeFn({
  131. values: eraValues,
  132. defaultWidth: "wide",
  133. }),
  134. quarter: buildLocalizeFn({
  135. values: quarterValues,
  136. defaultWidth: "wide",
  137. argumentCallback: (quarter) => quarter - 1,
  138. }),
  139. month: buildLocalizeFn({
  140. values: monthValues,
  141. defaultWidth: "wide",
  142. }),
  143. day: buildLocalizeFn({
  144. values: dayValues,
  145. defaultWidth: "wide",
  146. }),
  147. dayPeriod: buildLocalizeFn({
  148. values: dayPeriodValues,
  149. defaultWidth: "wide",
  150. formattingValues: formattingDayPeriodValues,
  151. defaultFormattingWidth: "wide",
  152. }),
  153. };