mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-10 11:33:17 +00:00
PHRAS-270 #time 3h
erase blank fields when writing metadatas = write back every field of the STRUCTURE, not only fields of the record.
This commit is contained in:

committed by
Nicolas Le Goff

parent
9cef4528db
commit
b05fb498da
@@ -13,12 +13,13 @@ use PHPExiftool\Driver\Metadata;
|
||||
use PHPExiftool\Driver\Value;
|
||||
use PHPExiftool\Driver\Tag;
|
||||
use PHPExiftool\Driver\TagFactory;
|
||||
use PHPExiftool\Writer;
|
||||
use PHPExiftool\Writer as ExifWriter;
|
||||
use PHPExiftool\Exception\TagUnknown;
|
||||
|
||||
class task_period_writemeta extends task_databoxAbstract
|
||||
{
|
||||
protected $clear_doc;
|
||||
protected $mwg;
|
||||
protected $metasubdefs = array();
|
||||
|
||||
private $_todo = 0; // set by "retrieveSbasContent", dec by "postProcessOneContent"
|
||||
@@ -31,6 +32,7 @@ class task_period_writemeta extends task_databoxAbstract
|
||||
protected function loadSettings(SimpleXMLElement $sx_task_settings)
|
||||
{
|
||||
$this->clear_doc = p4field::isyes($sx_task_settings->cleardoc);
|
||||
$this->mwg = p4field::isyes($sx_task_settings->mwg);
|
||||
parent::loadSettings($sx_task_settings);
|
||||
}
|
||||
|
||||
@@ -43,13 +45,13 @@ class task_period_writemeta extends task_databoxAbstract
|
||||
{
|
||||
$request = http_request::getInstance();
|
||||
|
||||
$parm2 = $request->get_parms('period', 'cleardoc', 'maxrecs', 'maxmegs');
|
||||
$parm2 = $request->get_parms('period', 'cleardoc', 'mwg', 'maxrecs', 'maxmegs');
|
||||
$dom = new DOMDocument();
|
||||
$dom->preserveWhiteSpace = false;
|
||||
$dom->formatOutput = true;
|
||||
if ($dom->loadXML($oldxml)) {
|
||||
$xmlchanged = false;
|
||||
foreach (array('str:period', 'str:maxrecs', 'str:maxmegs', 'boo:cleardoc') as $pname) {
|
||||
foreach (array('str:period', 'str:maxrecs', 'str:maxmegs', 'boo:cleardoc', 'boo:mwg') as $pname) {
|
||||
$ptype = substr($pname, 0, 3);
|
||||
$pname = substr($pname, 4);
|
||||
$pvalue = $parm2[$pname];
|
||||
@@ -105,6 +107,7 @@ class task_period_writemeta extends task_databoxAbstract
|
||||
<script type="text/javascript">
|
||||
<?php echo $form ?>.period.value = "<?php echo p4string::MakeString($sxml->period, "js", '"') ?>";
|
||||
<?php echo $form ?>.cleardoc.checked = <?php echo p4field::isyes($sxml->cleardoc) ? "true" : 'false' ?>;
|
||||
<?php echo $form ?>.mwg.checked = <?php echo p4field::isyes($sxml->mwg) ? "true" : 'false' ?>;
|
||||
<?php echo $form ?>.maxrecs.value = "<?php echo p4string::MakeString($sxml->maxrecs, "js", '"') ?>";
|
||||
<?php echo $form ?>.maxmegs.value = "<?php echo p4string::MakeString($sxml->maxmegs, "js", '"') ?>";
|
||||
</script>
|
||||
@@ -131,6 +134,7 @@ class task_period_writemeta extends task_databoxAbstract
|
||||
{
|
||||
period.value = xml.find("period").text();
|
||||
cleardoc.checked = Number(xml.find("cleardoc").text()) > 0;
|
||||
cleardoc.mwg = Number(xml.find("mwg").text()) > 0;
|
||||
maxrecs.value = xml.find("maxrecs").text();
|
||||
maxmegs.value = xml.find("maxmegs").text();
|
||||
}
|
||||
@@ -187,6 +191,14 @@ class task_period_writemeta extends task_databoxAbstract
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
<div class="control-group">
|
||||
<div class="controls">
|
||||
<label class="checkbox">
|
||||
<input class="formElem" type="checkbox" name="mwg">
|
||||
<?php echo _('task::writemeta:Compatibilité MWG') ?>
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
<div class="control-group">
|
||||
<label class="control-label"><?php echo _('Restart the task every X records') ?></label>
|
||||
<div class="controls">
|
||||
@@ -209,8 +221,6 @@ class task_period_writemeta extends task_databoxAbstract
|
||||
|
||||
protected function retrieveSbasContent(databox $databox)
|
||||
{
|
||||
$this->dependencyContainer['exiftool.writer']->setModule(Writer::MODULE_MWG, true);
|
||||
|
||||
$connbas = $databox->get_connection();
|
||||
$subdefgroups = $databox->get_subdef_structure();
|
||||
$metasubdefs = array();
|
||||
@@ -289,10 +299,13 @@ class task_period_writemeta extends task_databoxAbstract
|
||||
);
|
||||
}
|
||||
|
||||
foreach ($record->get_caption()->get_fields() as $field) {
|
||||
/* @var $caption \caption_record */
|
||||
$caption = $record->get_caption();
|
||||
/* @var $struct_field \databox_field */
|
||||
foreach($databox->get_meta_structure() as $struct_field_id=>$struct_field) {
|
||||
|
||||
$meta = $field->get_databox_field();
|
||||
$tagName = $meta->get_tag()->getTagname();
|
||||
$tagName = $struct_field->get_tag()->getTagname();
|
||||
$fieldName = $struct_field->get_name();
|
||||
|
||||
// skip fields with no src
|
||||
if($tagName == '') {
|
||||
@@ -306,34 +319,46 @@ class task_period_writemeta extends task_databoxAbstract
|
||||
continue;
|
||||
}
|
||||
|
||||
/* @var $meta \databox_field */
|
||||
try {
|
||||
/* @var $struct_field \databox_field */
|
||||
$field = $caption->get_field($fieldName);
|
||||
$datas = $field->get_values();
|
||||
|
||||
$datas = $field->get_values();
|
||||
if ($struct_field->is_multi()) {
|
||||
$values = array();
|
||||
foreach ($datas as $data) {
|
||||
$values[] = $data->getValue();
|
||||
}
|
||||
|
||||
if ($meta->is_multi()) {
|
||||
$values = array();
|
||||
foreach ($datas as $data) {
|
||||
$values[] = $data->getValue();
|
||||
$value = new Value\Multi($values);
|
||||
} else {
|
||||
$data = array_pop($datas);
|
||||
$value = $data->getValue();
|
||||
|
||||
$value = new Value\Mono($value);
|
||||
}
|
||||
} catch(\Exception $e) {
|
||||
// the field is not set in the record, erase it
|
||||
if ($struct_field->is_multi()) {
|
||||
$value = new Value\Multi(Array(""));
|
||||
}
|
||||
else {
|
||||
$value = new Value\Mono("");
|
||||
}
|
||||
|
||||
$value = new Value\Multi($values);
|
||||
} else {
|
||||
$data = array_pop($datas);
|
||||
$value = $data->getValue();
|
||||
|
||||
$value = new Value\Mono($value);
|
||||
}
|
||||
|
||||
$metadatas->add(
|
||||
new Metadata\Metadata($meta->get_tag(), $value)
|
||||
new Metadata\Metadata($struct_field->get_tag(), $value)
|
||||
);
|
||||
}
|
||||
|
||||
$this->dependencyContainer['exiftool.writer']->reset();
|
||||
if($this->mwg) {
|
||||
$this->dependencyContainer['exiftool.writer']->setModule(ExifWriter::MODULE_MWG, true);
|
||||
}
|
||||
|
||||
foreach ($tsub as $name => $file) {
|
||||
|
||||
$this->dependencyContainer['exiftool.writer']->erase($name != 'document' || $this->clear_doc, true);
|
||||
|
||||
try {
|
||||
$this->dependencyContainer['exiftool.writer']->write($file, $metadatas);
|
||||
|
||||
@@ -382,6 +407,7 @@ class task_period_writemeta extends task_databoxAbstract
|
||||
<maxrecs>%s</maxrecs>
|
||||
<maxmegs>%s</maxmegs>
|
||||
<cleardoc>0</cleardoc>
|
||||
<mwg>0</mwg>
|
||||
</tasksettings>',
|
||||
min(max($period, self::MINPERIOD), self::MAXPERIOD),
|
||||
min(max($maxrecs, self::MINRECS), self::MAXRECS),
|
||||
|
Reference in New Issue
Block a user