fr.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <?php
  2. // sunday first as date('w') is zero-based on sunday
  3. $days = array(
  4. 'dimanche',
  5. 'lundi',
  6. 'mardi',
  7. 'mercredi',
  8. 'jeudi',
  9. 'vendredi',
  10. 'samedi',
  11. );
  12. $months = array(
  13. 'janvier',
  14. 'février',
  15. 'mars',
  16. 'avril',
  17. 'mai',
  18. 'juin',
  19. 'juillet',
  20. 'août',
  21. 'septembre',
  22. 'octobre',
  23. 'novembre',
  24. 'décembre',
  25. );
  26. return array(
  27. 'Unable to fully convert this rrule to text.' => 'Cette règle de récurrence n\'a pas pu être convertie en texte.',
  28. 'for %count% times' => '%count% fois',
  29. 'for one time' => 'une fois',
  30. '(~ approximate)' => '(~ approximation)',
  31. 'until %date%' => 'jusqu\'au %date%', // e.g. every year until July 4, 2014
  32. 'day_date' => function ($str, $params) use ($days, $months) { // outputs a day date, e.g. 4 juillet, 2014
  33. return date('j ', $params['date']) . $months[date('n', $params['date']) - 1] . date(', Y', $params['date']);
  34. },
  35. 'day_month' => function ($str, $params) use ($days, $months) { // outputs a day month, e.g. July 4
  36. return $params['day'].' '.$months[$params['month'] - 1];
  37. },
  38. 'day_names' => $days,
  39. 'month_names' => $months,
  40. 'and' => 'et',
  41. 'or' => 'ou',
  42. 'in_month' => 'en', // e.g. weekly in January, May and August
  43. 'in_week' => 'en', // e.g. yearly in week 3
  44. 'on' => 'le', // e.g. every day on Tuesday, Wednesday and Friday
  45. 'the_for_monthday' => 'le', // e.g. monthly on Tuesday the 1st
  46. 'the_for_weekday' => '', // e.g. monthly on the 4th Monday
  47. 'on the' => 'le', // e.g. every year on the 1st and 200th day
  48. 'of_the_month' => 'du mois', // e.g. every year on the 2nd or 3rd of the month
  49. 'every %count% years' => 'tous les %count% ans',
  50. 'every year' => 'chaque année',
  51. 'every_month_list' => 'chaque', // e.g. every January, May and August
  52. 'every %count% months' => 'tous les %count% mois',
  53. 'every month' => 'chaque mois',
  54. 'every %count% weeks' => 'toutes les %count% semaines',
  55. 'every week' => 'chaque semaine',
  56. 'every %count% days' => 'tous les %count% jours',
  57. 'every day' => 'chaque jour',
  58. 'every %count% hours' => 'toutes les %count% heures',
  59. 'every hour' => 'chaque heure',
  60. 'last' => 'dernier', // e.g. 2nd last Friday
  61. 'days' => 'jours',
  62. 'day' => 'jour',
  63. 'weeks' => 'semaines',
  64. 'week' => 'semaine',
  65. 'hours' => 'heures',
  66. 'hour' => 'heure',
  67. // formats a number with a prefix e.g. every year on the 1st and 200th day
  68. // negative numbers should be handled as in '5th to the last' or 'last'
  69. //
  70. // if has_negatives is true in the params, it is good form to add 'day' after
  71. // each number, as in: 'every month on the 5th day or 2nd to the last day' or
  72. // it may be confusing like 'every month on the 5th or 2nd to the last day'
  73. 'ordinal_number' => function ($str, $params) {
  74. $number = $params['number'];
  75. $suffix = '';
  76. $isNegative = $number < 0;
  77. if ($number == -1) {
  78. $abbreviation = 'dernier';
  79. } elseif ($number == -2) {
  80. $abbreviation = 'avant dernier';
  81. } elseif ($isNegative) {
  82. $number = abs($number);
  83. $abbreviation = $number . 'ème au dernier';
  84. } elseif ($number == 1 && (!$params['day_in_month'])) {
  85. $abbreviation = $number . 'er';
  86. } else if (!$params['day_in_month']) {
  87. $abbreviation = $number . 'ème';
  88. }
  89. else {
  90. $abbreviation = $number;
  91. }
  92. if (!empty($params['has_negatives'])) {
  93. $suffix .= ' jour';
  94. }
  95. return $abbreviation . $suffix;
  96. },
  97. );