1<?php 2/** 3 * webtrees: online genealogy 4 * Copyright (C) 2017 webtrees development team 5 * This program is free software: you can redistribute it and/or modify 6 * it under the terms of the GNU General Public License as published by 7 * the Free Software Foundation, either version 3 of the License, or 8 * (at your option) any later version. 9 * This program is distributed in the hope that it will be useful, 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 * GNU General Public License for more details. 13 * You should have received a copy of the GNU General Public License 14 * along with this program. If not, see <http://www.gnu.org/licenses/>. 15 */ 16namespace Fisharebest\Webtrees\Date; 17 18use Fisharebest\ExtCalendar\FrenchCalendar; 19use Fisharebest\Webtrees\I18N; 20 21/** 22 * Definitions for the French Republican calendar 23 */ 24class FrenchDate extends CalendarDate { 25 /** @var int[] Convert GEDCOM month names to month numbers */ 26 public static $MONTH_ABBREV = ['' => 0, 'VEND' => 1, 'BRUM' => 2, 'FRIM' => 3, 'NIVO' => 4, 'PLUV' => 5, 'VENT' => 6, 'GERM' => 7, 'FLOR' => 8, 'PRAI' => 9, 'MESS' => 10, 'THER' => 11, 'FRUC' => 12, 'COMP' => 13]; 27 28 /** 29 * Create a date from either: 30 * a Julian day number 31 * day/month/year strings from a GEDCOM date 32 * another CalendarDate object 33 * 34 * @param array|int|CalendarDate $date 35 */ 36 public function __construct($date) { 37 $this->calendar = new FrenchCalendar; 38 parent::__construct($date); 39 } 40 41 /** 42 * Full month name in nominative case. 43 * 44 * @param int $month_number 45 * @param bool $leap_year Some calendars use leap months 46 * 47 * @return string 48 */ 49 public static function monthNameNominativeCase($month_number, $leap_year) { 50 static $translated_month_names; 51 52 if ($translated_month_names === null) { 53 $translated_month_names = [ 54 0 => '', 55 1 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Vendemiaire'), 56 2 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Brumaire'), 57 3 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Frimaire'), 58 4 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Nivose'), 59 5 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Pluviose'), 60 6 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Ventose'), 61 7 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Germinal'), 62 8 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Floreal'), 63 9 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Prairial'), 64 10 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Messidor'), 65 11 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Thermidor'), 66 12 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'Fructidor'), 67 13 => /* I18N: a month in the French republican calendar */ I18N::translateContext('NOMINATIVE', 'jours complementaires'), 68 ]; 69 } 70 71 return $translated_month_names[$month_number]; 72 } 73 74 /** 75 * Full month name in genitive case. 76 * 77 * @param int $month_number 78 * @param bool $leap_year Some calendars use leap months 79 * 80 * @return string 81 */ 82 protected function monthNameGenitiveCase($month_number, $leap_year) { 83 static $translated_month_names; 84 85 if ($translated_month_names === null) { 86 $translated_month_names = [ 87 0 => '', 88 1 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Vendemiaire'), 89 2 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Brumaire'), 90 3 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Frimaire'), 91 4 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Nivose'), 92 5 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Pluviose'), 93 6 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Ventose'), 94 7 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Germinal'), 95 8 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Floreal'), 96 9 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Prairial'), 97 10 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Messidor'), 98 11 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Thermidor'), 99 12 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'Fructidor'), 100 13 => /* I18N: a month in the French republican calendar */ I18N::translateContext('GENITIVE', 'jours complementaires'), 101 ]; 102 } 103 104 return $translated_month_names[$month_number]; 105 } 106 107 /** 108 * Full month name in locative case. 109 * 110 * @param int $month_number 111 * @param bool $leap_year Some calendars use leap months 112 * 113 * @return string 114 */ 115 protected function monthNameLocativeCase($month_number, $leap_year) { 116 static $translated_month_names; 117 118 if ($translated_month_names === null) { 119 $translated_month_names = [ 120 0 => '', 121 1 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Vendemiaire'), 122 2 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Brumaire'), 123 3 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Frimaire'), 124 4 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Nivose'), 125 5 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Pluviose'), 126 6 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Ventose'), 127 7 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Germinal'), 128 8 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Floreal'), 129 9 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Prairial'), 130 10 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Messidor'), 131 11 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Thermidor'), 132 12 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'Fructidor'), 133 13 => /* I18N: a month in the French republican calendar */ I18N::translateContext('LOCATIVE', 'jours complementaires'), 134 ]; 135 } 136 137 return $translated_month_names[$month_number]; 138 } 139 140 /** 141 * Full month name in instrumental case. 142 * 143 * @param int $month_number 144 * @param bool $leap_year Some calendars use leap months 145 * 146 * @return string 147 */ 148 protected function monthNameInstrumentalCase($month_number, $leap_year) { 149 static $translated_month_names; 150 151 if ($translated_month_names === null) { 152 $translated_month_names = [ 153 0 => '', 154 1 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Vendemiaire'), 155 2 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Brumaire'), 156 3 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Frimaire'), 157 4 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Nivose'), 158 5 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Pluviose'), 159 6 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Ventose'), 160 7 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Germinal'), 161 8 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Floreal'), 162 9 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Prairial'), 163 10 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Messidor'), 164 11 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Thermidor'), 165 12 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'Fructidor'), 166 13 => /* I18N: a month in the French republican calendar */ I18N::translateContext('INSTRUMENTAL', 'jours complementaires'), 167 ]; 168 } 169 170 return $translated_month_names[$month_number]; 171 } 172 173 /** 174 * Abbreviated month name 175 * 176 * @param int $month_number 177 * @param bool $leap_year Some calendars use leap months 178 * 179 * @return string 180 */ 181 protected function monthNameAbbreviated($month_number, $leap_year) { 182 return self::monthNameNominativeCase($month_number, $leap_year); 183 } 184 185 /** 186 * Full day of th eweek 187 * 188 * @param int $day_number 189 * 190 * @return string 191 */ 192 public function dayNames($day_number) { 193 static $translated_day_names; 194 195 if ($translated_day_names === null) { 196 $translated_day_names = [ 197 0 => /* I18N: The first day in the French republican calendar */ I18N::translate('Primidi'), 198 1 => /* I18N: The second day in the French republican calendar */ I18N::translate('Duodi'), 199 2 => /* I18N: The third day in the French republican calendar */ I18N::translate('Tridi'), 200 3 => /* I18N: The fourth day in the French republican calendar */ I18N::translate('Quartidi'), 201 4 => /* I18N: The fifth day in the French republican calendar */ I18N::translate('Quintidi'), 202 5 => /* I18N: The sixth day in the French republican calendar */ I18N::translate('Sextidi'), 203 6 => /* I18N: The seventh day in the French republican calendar */ I18N::translate('Septidi'), 204 7 => /* I18N: The eighth day in the French republican calendar */ I18N::translate('Octidi'), 205 8 => /* I18N: The ninth day in the French republican calendar */ I18N::translate('Nonidi'), 206 9 => /* I18N: The tenth day in the French republican calendar */ I18N::translate('Decidi'), 207 ]; 208 } 209 210 return $translated_day_names[$day_number]; 211 } 212 213 /** 214 * Abbreviated day of the week 215 * 216 * @param int $day_number 217 * 218 * @return string 219 */ 220 protected function dayNamesAbbreviated($day_number) { 221 return $this->dayNames($day_number); 222 } 223 224 /** 225 * Generate the %Y format for a date. 226 * 227 * @return string 228 */ 229 protected function formatLongYear() { 230 return $this->numberToRomanNumerals($this->y); 231 } 232} 233