. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Statistics\Google; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Module\ModuleThemeInterface; use Fisharebest\Webtrees\Statistics\Helper\Century; use Fisharebest\Webtrees\Statistics\AbstractGoogle; use Fisharebest\Webtrees\Tree; use Illuminate\Database\Capsule\Manager as DB; /** * */ class ChartDeath extends AbstractGoogle { /** * @var Tree */ private $tree; /** * @var Century */ private $centuryHelper; /** * Constructor. * * @param Tree $tree */ public function __construct(Tree $tree) { $this->tree = $tree; $this->centuryHelper = new Century(); } /** * Returns the related database records. * * @return \stdClass[] */ private function queryRecords(): array { $query = DB::table('dates') ->selectRaw('FLOOR(d_year / 100 + 1) AS century') ->selectRaw('COUNT(*) AS total') ->where('d_file', '=', $this->tree->id()) ->where('d_year', '<>', 0) ->where('d_fact', '=', 'DEAT') ->whereIn('d_type', ['@#DGREGORIAN@', '@#DJULIAN@']) ->groupBy(['century']) ->orderBy('century'); return $query->get()->all(); } /** * Create a chart of death places. * * @param string|null $size * @param string|null $color_from * @param string|null $color_to * * @return string */ public function chartDeath(string $size = null, string $color_from = null, string $color_to = null): string { $chart_color1 = (string) app()->make(ModuleThemeInterface::class)->parameter('distribution-chart-no-values'); $chart_color2 = (string) app()->make(ModuleThemeInterface::class)->parameter('distribution-chart-high-values'); $chart_x = app()->make(ModuleThemeInterface::class)->parameter('stats-small-chart-x'); $chart_y = app()->make(ModuleThemeInterface::class)->parameter('stats-small-chart-y'); $size = $size ?? ($chart_x . 'x' . $chart_y); $color_from = $color_from ?? $chart_color1; $color_to = $color_to ?? $chart_color2; $sizes = explode('x', $size); $tot = 0; $rows = $this->queryRecords(); foreach ($rows as $values) { $values->total = (int) $values->total; $tot += $values->total; } // Beware divide by zero if ($tot === 0) { return ''; } $centuries = ''; $counts = []; foreach ($rows as $values) { $counts[] = intdiv(100 * $values->total, $tot); $centuries .= $this->centuryHelper->centuryName((int) $values->century) . ' - ' . I18N::number($values->total) . '|'; } $chd = $this->arrayToExtendedEncoding($counts); $chl = rawurlencode(substr($centuries, 0, -1)); $colors = [$color_from, $color_to]; return view( 'statistics/other/chart-google', [ 'chart_title' => I18N::translate('Deaths by century'), 'chart_url' => $this->getPieChartUrl($chd, $size, $colors, $chl), 'sizes' => $sizes, ] ); } }