. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Statistics\Google; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Module\ModuleThemeInterface; use Fisharebest\Webtrees\Statistics\Service\ColorService; use Fisharebest\Webtrees\Tree; /** * A chart showing the top surnames. */ class ChartCommonSurname { /** * @var ModuleThemeInterface */ private $theme; /** * @var string */ private $surname_tradition; /** * @var ColorService */ private $color_service; /** * Constructor. * * @param Tree $tree */ public function __construct(Tree $tree) { $this->theme = app()->make(ModuleThemeInterface::class); $this->surname_tradition = $tree->getPreference('SURNAME_TRADITION'); $this->color_service = new ColorService(); } /** * Count up the different versions of a name and returns the one with the most matches. Takes * different surname traditions into account. * * @param array $surns * * @return array [ name, count ] */ private function getTopNameAndCount(array $surns): array { $max_name = 0; $count_per = 0; $top_name = ''; foreach ($surns as $spfxsurn => $count) { $per = $count; $count_per += $per; // select most common surname from all variants if ($per > $max_name) { $max_name = $per; $top_name = $spfxsurn; } } if ($this->surname_tradition === 'polish') { // Most common surname should be in male variant (Kowalski, not Kowalska) $top_name = preg_replace( [ '/ska$/', '/cka$/', '/dzka$/', '/żka$/', ], [ 'ski', 'cki', 'dzki', 'żki', ], $top_name ); } return [ $top_name, $count_per ]; } /** * Create a chart of common surnames. * * @param int $tot_indi The total number of individuals * @param array $all_surnames The list of common surnames * @param string|null $color_from * @param string|null $color_to * * @return string */ public function chartCommonSurnames( int $tot_indi, array $all_surnames, string $color_from = null, string $color_to = null ): string { $chart_color1 = (string) $this->theme->parameter('distribution-chart-no-values'); $chart_color2 = (string) $this->theme->parameter('distribution-chart-high-values'); $color_from = $color_from ?? $chart_color1; $color_to = $color_to ?? $chart_color2; $tot = 0; foreach ($all_surnames as $surn => $surnames) { $tot += array_sum($surnames); } $data = [ [ I18N::translate('Name'), I18N::translate('Total') ], ]; foreach ($all_surnames as $surns) { $data[] = $this->getTopNameAndCount($surns); } $data[] = [ I18N::translate('Other'), $tot_indi - $tot ]; $colors = $this->color_service->interpolateRgb($color_from, $color_to, \count($data) - 1); return view( 'statistics/other/charts/pie', [ 'title' => null, 'data' => $data, 'colors' => $colors, ] ); } }