Я намагаюся відобразити результати веб-форми як графіки Google . Я роблю це на шарі теми, переосмислюючи topic_webform_results_analysis () у файлі template.php моєї теми та використовуючи модуль Chart . Drupal 6.22, Webform 6.x-3.11.
Сторінка аналізу веб-форм зазвичай показує дані в таблиці, тому я намагаюся зламати масиви для цієї таблиці, щоб передавати речі в API Chart .
EDIT : Я зрозумів, як використовувати var_dump, і виявив, що кращим підходом може бути вставання в масиви $ row_data та $ questions окремо (замість того, щоб використовувати масив $ рядків, який у мене був у першій версії цього питання, що було розшарування обох масивів).
РЕДАКТИКА №2 : Я думаю, що я виявив, як схопити кожен фрагмент початкових $ питань та масивів $ row_data (див. Нижче - передбачення в іншому foreach). Тож тепер мені потрібно скласти ці шматки у правильні масиви (1 за запитання) і знайти спосіб пройти через все це.
Ось що я отримав у template.php:
/**
* Output the content of the Analysis page.
* @see webform_results_analysis()
*/
function mytheme_webform_results_analysis($node, $data, $sids = array(), $analysis_component = NULL) {
foreach ($data as $cid => $row_data) {
if (is_array($row_data)) {
// get the questions, put them in an array
$questions = array();
$questions[] = array('data' => check_plain($node->webform['components'][$cid]['name']));
// this will print everything out in the right order - it really needs to
// make an array for each question that looks like $test_chart below
foreach ($questions as $question) {
print $question['data'] . '<br />'; // questions
foreach ($row_data as $key => $value) {
print $value[0] . '<br />'; // labels
print $value[1] . '<br />'; // results
}
}
// Set up the chart
$chart = array(
'#chart_id' => 'webform_analysis',
'#type' => CHART_TYPE_PIE_3D,
'#size' => chart_size(658, 250)
);
// not real data here, this just shows the format I'm shooting for
$test_chart = array(
'option 1' => '12',
'option 2' => '45',
'option 3' => '122'
);
// separate the above array into labels and values, add a percentage to the label
foreach ($test_chart as $key => $value) {
$chart['#data'][] = $test_chart[$key];
$chart['#labels'][] = strip_tags($key) . ' (' . round($test_chart[$key], 2) . '%)';
}
// pick some colors
$chart['#data_colors'][] = 'b0c73d';
$chart['#data_colors'][] = '667323';
$chart['#data_colors'][] = '221f1f';
$output = chart_render($chart);
}
}
if (count($row_data) == 0) {
$output = t('There are no submissions for this form.');
}
// return the data that goes into chart function, just for testing
// return $chart_data;
// someday, this might return a set of webform charts. right now it returns the fake test chart
// return $output;
}