mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-13 17:38:19 +01:00
Api: Add some extra parameters to Merge::merge_entries() so overridding classes can still use the parent method, passing in IDs & merge object
This commit is contained in:
parent
8f93a7f7c6
commit
6c0aed651f
@ -2333,14 +2333,19 @@ abstract class Merge
|
|||||||
/**
|
/**
|
||||||
* Merge the selected IDs into the given document, save it to the VFS, then
|
* Merge the selected IDs into the given document, save it to the VFS, then
|
||||||
* either open it in the editor or have the browser download the file.
|
* either open it in the editor or have the browser download the file.
|
||||||
|
*
|
||||||
|
* @param String[]|null $ids Allows extending classes to process IDs in their own way. Leave null to pull from request.
|
||||||
|
* @param Merge|null $document_merge Already instantiated Merge object to do the merge.
|
||||||
|
* @throws Api\Exception
|
||||||
|
* @throws Api\Exception\AssertionFailed
|
||||||
*/
|
*/
|
||||||
public static function merge_entries()
|
public static function merge_entries(array $ids = null, Merge &$document_merge = null)
|
||||||
{
|
{
|
||||||
if (class_exists($_REQUEST['merge']) && is_subclass_of($_REQUEST['merge'], 'EGroupware\\Api\\Storage\\Merge'))
|
if (is_null($document_merge) && class_exists($_REQUEST['merge']) && is_subclass_of($_REQUEST['merge'], 'EGroupware\\Api\\Storage\\Merge'))
|
||||||
{
|
{
|
||||||
$document_merge = new $_REQUEST['merge']();
|
$document_merge = new $_REQUEST['merge']();
|
||||||
}
|
}
|
||||||
else
|
elseif (is_null($document_merge))
|
||||||
{
|
{
|
||||||
$document_merge = new Api\Contacts\Merge();
|
$document_merge = new Api\Contacts\Merge();
|
||||||
}
|
}
|
||||||
@ -2351,13 +2356,16 @@ abstract class Merge
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(is_null(($ids)))
|
||||||
|
{
|
||||||
$ids = is_string($_REQUEST['id']) && strpos($_REQUEST['id'], '[') === FALSE ? explode(',', $_REQUEST['id']) : json_decode($_REQUEST['id'], true);
|
$ids = is_string($_REQUEST['id']) && strpos($_REQUEST['id'], '[') === FALSE ? explode(',', $_REQUEST['id']) : json_decode($_REQUEST['id'], true);
|
||||||
|
}
|
||||||
if($_REQUEST['select_all'] === 'true')
|
if($_REQUEST['select_all'] === 'true')
|
||||||
{
|
{
|
||||||
$ids = self::get_all_ids($document_merge);
|
$ids = self::get_all_ids($document_merge);
|
||||||
}
|
}
|
||||||
|
|
||||||
$filename = '';
|
$filename = $document_merge->get_filename($_REQUEST['document']);
|
||||||
$result = $document_merge->merge_file($_REQUEST['document'], $ids, $filename, '', $header);
|
$result = $document_merge->merge_file($_REQUEST['document'], $ids, $filename, '', $header);
|
||||||
|
|
||||||
if(!is_file($result) || !is_readable($result))
|
if(!is_file($result) || !is_readable($result))
|
||||||
@ -2412,6 +2420,17 @@ abstract class Merge
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate a filename for the merged file
|
||||||
|
*
|
||||||
|
* Default is just the name of the template
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
protected function get_filename($document) : string
|
||||||
|
{
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get all ids for when they try to do 'Select All', then merge into document
|
* Get all ids for when they try to do 'Select All', then merge into document
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user