silverstripe-userforms/code/Model/Submission/SubmittedFileField.php

110 lines
2.5 KiB
PHP
Raw Normal View History

<?php
namespace SilverStripe\UserForms\Model\Submission;
use SilverStripe\Assets\File;
use SilverStripe\ORM\FieldType\DBField;
use SilverStripe\Versioned\Versioned;
/**
2015-09-11 10:20:06 +12:00
* A file uploaded on a {@link UserDefinedForm} and attached to a single
* {@link SubmittedForm}.
*
* @package userforms
* @property int $UploadedFileID
* @method File UploadedFile()
*/
2016-07-21 17:53:59 +12:00
class SubmittedFileField extends SubmittedFormField
{
private static $has_one = [
'UploadedFile' => File::class
];
2015-09-11 10:20:06 +12:00
private static $table_name = 'SubmittedFileField';
2015-09-11 10:20:06 +12:00
private static $owns = [
'UploadedFile'
];
private static $cascade_deletes = [
'UploadedFile'
];
2016-07-21 17:53:59 +12:00
/**
* Return the value of this field for inclusion into things such as
* reports.
*
* @return string
*/
public function getFormattedValue()
{
$name = $this->getFileName();
$link = $this->getLink();
$title = _t(__CLASS__ . '.DOWNLOADFILE', 'Download File');
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
if ($link) {
return DBField::create_field('HTMLText', sprintf(
'%s - <a href="%s" target="_blank">%s</a>',
2017-08-11 12:37:03 +12:00
$name,
$link,
$title
2016-07-21 17:53:59 +12:00
));
}
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
return false;
}
2015-09-11 10:20:06 +12:00
2016-07-21 17:53:59 +12:00
/**
* Return the value for this field in the CSV export.
*
* @return string
*/
public function getExportValue()
{
return ($link = $this->getLink()) ? $link : '';
2016-07-21 17:53:59 +12:00
}
2016-07-21 17:53:59 +12:00
/**
* Return the link for the file attached to this submitted form field.
*
* @return string
*/
public function getLink()
{
if ($file = $this->getUploadedFileFromDraft()) {
if ($file->exists()) {
return $file->getAbsoluteURL();
2016-07-21 17:53:59 +12:00
}
}
}
2015-09-11 10:20:06 +12:00
/**
* As uploaded files are stored in draft by default, this retrieves the
* uploaded file from draft mode rather than using the current stage.
*
* @return File
*/
public function getUploadedFileFromDraft()
{
$fileId = $this->UploadedFileID;
return Versioned::withVersionedMode(function () use ($fileId) {
Versioned::set_stage(Versioned::DRAFT);
return File::get()->byID($fileId);
});
}
2016-07-21 17:53:59 +12:00
/**
* Return the name of the file, if present
*
* @return string
*/
public function getFileName()
{
if ($file = $this->getUploadedFileFromDraft()) {
return $file->Name;
2016-07-21 17:53:59 +12:00
}
}
2015-07-24 14:37:48 +12:00
}