mirror of
https://github.com/moodle/moodle.git
synced 2025-04-14 13:02:07 +02:00
MDL-67547 dataformat: allow plugins to declare support for HTML.
This commit is contained in:
parent
a09eb2697f
commit
118a109499
@ -92,6 +92,15 @@ table {
|
||||
echo \html_writer::end_tag('tr');
|
||||
}
|
||||
|
||||
/**
|
||||
* Method to define whether the dataformat supports export of HTML
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function supports_html(): bool {
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Write a single record
|
||||
*
|
||||
@ -99,6 +108,8 @@ table {
|
||||
* @param int $rownum
|
||||
*/
|
||||
public function write_record($record, $rownum) {
|
||||
$record = $this->format_record($record);
|
||||
|
||||
echo \html_writer::start_tag('tr');
|
||||
foreach ($record as $cell) {
|
||||
echo \html_writer::tag('td', $cell);
|
||||
|
@ -80,7 +80,7 @@ class writer extends \core\dataformat\base {
|
||||
echo ",";
|
||||
}
|
||||
|
||||
echo json_encode($record, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
|
||||
echo json_encode($this->format_record($record), JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
|
||||
|
||||
$this->sheetdatadded = true;
|
||||
}
|
||||
|
@ -93,14 +93,25 @@ class writer extends \core\dataformat\base {
|
||||
$this->print_heading();
|
||||
}
|
||||
|
||||
/**
|
||||
* Method to define whether the dataformat supports export of HTML
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function supports_html(): bool {
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Write a single record
|
||||
*
|
||||
* @param array $record
|
||||
* @param int $rownum
|
||||
*/
|
||||
public function write_record($record, $rownum) {
|
||||
$rowheight = 0;
|
||||
|
||||
// If $record is an object convert it to an array.
|
||||
if (is_object($record)) {
|
||||
$record = (array)$record;
|
||||
}
|
||||
|
||||
$record = $this->format_record($record);
|
||||
foreach ($record as $cell) {
|
||||
$rowheight = max($rowheight, $this->pdf->getStringHeight($this->colwidth, $cell, false, true, '', 1));
|
||||
}
|
||||
@ -123,7 +134,7 @@ class writer extends \core\dataformat\base {
|
||||
// Determine whether we're at the last element of the record.
|
||||
$nextposition = ($lastkey === $key) ? 1 : 0;
|
||||
// Write the element.
|
||||
$this->pdf->Multicell($this->colwidth, $rowheight, $cell, 1, 'L', false, $nextposition);
|
||||
$this->pdf->writeHTMLCell($this->colwidth, $rowheight, '', '', $cell, 1, $nextposition, false, true, 'L');
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -145,6 +145,27 @@ abstract class base {
|
||||
// Override me if needed.
|
||||
}
|
||||
|
||||
/**
|
||||
* Method to define whether the dataformat supports export of HTML
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function supports_html(): bool {
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Apply formatting to the cells of a given record
|
||||
*
|
||||
* @param array|\stdClass $record
|
||||
* @return array
|
||||
*/
|
||||
protected function format_record($record): array {
|
||||
$record = (array)$record;
|
||||
|
||||
return $record;
|
||||
}
|
||||
|
||||
/**
|
||||
* Write a single record
|
||||
*
|
||||
|
@ -116,11 +116,11 @@ abstract class spout_base extends \core\dataformat\base {
|
||||
/**
|
||||
* Write a single record
|
||||
*
|
||||
* @param object $record
|
||||
* @param array $record
|
||||
* @param int $rownum
|
||||
*/
|
||||
public function write_record($record, $rownum) {
|
||||
$row = \Box\Spout\Writer\Common\Creator\WriterEntityFactory::createRowFromArray((array)$record);
|
||||
$row = \Box\Spout\Writer\Common\Creator\WriterEntityFactory::createRowFromArray($this->format_record($record));
|
||||
$this->writer->addRow($row);
|
||||
}
|
||||
|
||||
|
@ -2012,7 +2012,7 @@ class table_default_export_format_parent {
|
||||
*/
|
||||
class table_dataformat_export_format extends table_default_export_format_parent {
|
||||
|
||||
/** @var $dataformat */
|
||||
/** @var \core\dataformat\base $dataformat */
|
||||
protected $dataformat;
|
||||
|
||||
/** @var $rownum */
|
||||
@ -2047,6 +2047,15 @@ class table_dataformat_export_format extends table_default_export_format_parent
|
||||
\core\session\manager::write_close();
|
||||
}
|
||||
|
||||
/**
|
||||
* Whether the current dataformat supports export of HTML
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function supports_html(): bool {
|
||||
return $this->dataformat->supports_html();
|
||||
}
|
||||
|
||||
/**
|
||||
* Start document
|
||||
*
|
||||
|
Loading…
x
Reference in New Issue
Block a user