ENH Improve gridfield export pefromance by using DataList generator

This commit is contained in:
Mojmir Fendek 2022-01-11 09:53:42 +13:00
parent acb04e3d17
commit 048eb4b614

View File

@ -6,6 +6,7 @@ use League\Csv\Writer;
use SilverStripe\Control\HTTPRequest; use SilverStripe\Control\HTTPRequest;
use SilverStripe\Control\HTTPResponse; use SilverStripe\Control\HTTPResponse;
use SilverStripe\Core\Config\Config; use SilverStripe\Core\Config\Config;
use SilverStripe\ORM\DataList;
use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DataObject;
/** /**
@ -220,8 +221,15 @@ class GridFieldExportButton implements GridField_HTMLProvider, GridField_ActionP
? $gridFieldColumnsComponent->getColumnsHandled($gridField) ? $gridFieldColumnsComponent->getColumnsHandled($gridField)
: []; : [];
// Remove limit as the list may be paginated, we want the full list for the export
$items = $items->limit(null);
// Use Generator in applicable cases to reduce memory consumption
$items = $items instanceof DataList
? $items->getGenerator()
: $items;
/** @var DataObject $item */ /** @var DataObject $item */
foreach ($items->limit(null) as $item) { foreach ($items as $item) {
if (!$item->hasMethod('canView') || $item->canView()) { if (!$item->hasMethod('canView') || $item->canView()) {
$columnData = []; $columnData = [];