This repository has been archived on 2024-09-05. You can view files and clone it, but cannot push or open issues or pull requests.
shimmie2/ext/view/events/image_info_set_event.php
Shish db0e788a67 [core] Deduplicate ImageAdditionEvent & ImageInfoSetEvent
Rather than ImageAddition triggering TagsSet/SourceSet/LockSet etc in one way, and ImageInfoSet triggering TagsSet/SourceSet/LockSet in a different way, why not have ImageAddition *just* deal with image addition, and then send a separate ImageInfoSet to deal with all of the metadata setting?
2024-02-20 22:15:24 +00:00

49 lines
1.4 KiB
PHP

<?php
declare(strict_types=1);
namespace Shimmie2;
class ImageInfoSetEvent extends Event
{
public Image $image;
public int $slot;
/** @var array<string, string> */
public array $params;
/**
* currently all post metadata is string => string - in the future
* we might want to have a more complex type system, but for now
* we just filter out non-string keys (eg, `only_strings($_POST)`)
*
* @param array<string, string> $params
*/
public function __construct(Image $image, int $slot, array $params)
{
parent::__construct();
$this->image = $image;
$this->slot = $slot;
$this->params = $params;
}
/**
* Get a slot-specific value, or a common value, or null. This allows
* a user to POST an update to multiple images at once, setting eg
* "source" to be a common default source and "source12" to be a
* specific source for image 12.
*
* Specifically we check for "empty" rather than "isset" because
* the upload form might have a "source" field that is empty, and
* we want to allow non-empty values to override empty ones.
*/
public function get_param(string $name): ?string
{
if(!empty($this->params["$name{$this->slot}"])) {
return $this->params["$name{$this->slot}"];
}
if(!empty($this->params[$name])) {
return $this->params[$name];
}
return null;
}
}