2020-08-06 17:32:29 +02:00
|
|
|
<?PHP
|
|
|
|
/**
|
|
|
|
* Contains a class for controlling the list of available events.
|
|
|
|
*
|
|
|
|
* @author Joshua Ramon Enslin <joshua@museum-digital.de>
|
|
|
|
*/
|
2020-08-07 00:12:49 +02:00
|
|
|
declare(strict_types = 1);
|
2020-08-06 17:32:29 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Class containing available units for events.
|
|
|
|
*/
|
2020-08-29 17:21:18 +02:00
|
|
|
final class MDEventsSet extends MDValueSet {
|
2020-08-06 17:32:29 +02:00
|
|
|
|
2023-10-15 13:29:12 +02:00
|
|
|
public const EVENT_IDS = [
|
2020-08-06 17:32:29 +02:00
|
|
|
'1', // => Created
|
|
|
|
'2', // => Found
|
|
|
|
'3', // => Published
|
|
|
|
'4', // => Template creation
|
|
|
|
'5', // => Was depicted (Actor)
|
|
|
|
'6', // => Was used
|
|
|
|
'7', // => Written
|
|
|
|
'8', // => Collected
|
|
|
|
'9', // => Painted
|
|
|
|
'10', // => Image taken
|
|
|
|
'11', // => Received
|
|
|
|
'12', // => Printing plate produced
|
|
|
|
'13', // => Sent
|
|
|
|
'14', // => Issued
|
|
|
|
'15', // => Signed
|
|
|
|
'16', // => First description
|
|
|
|
'19', // => Drawn
|
|
|
|
'20', // => Copied (by hand)
|
|
|
|
'21', // => Lived
|
|
|
|
'22', // => [Relationship to location]
|
|
|
|
'23', // => [Relation to person or institution]
|
|
|
|
'24', // => [Relation to time]
|
|
|
|
'25', // => Commissioned
|
|
|
|
'26', // => Printed
|
|
|
|
'27', // => Recorded
|
|
|
|
'28', // => Sung
|
|
|
|
'29', // => Decor designed
|
|
|
|
'30', // => Form designed
|
|
|
|
'31', // => Modelled
|
|
|
|
'32', // => Autographed/Signed
|
|
|
|
'33', // => Mentioned
|
|
|
|
'34', // => Buried
|
|
|
|
'35', // => Intellectual creation
|
|
|
|
'36', // => Was depicted
|
|
|
|
'37', // => Painted on
|
|
|
|
'38', // => Illustrated
|
2023-10-15 18:31:52 +02:00
|
|
|
'39', // => Assembled / "wurde zusammengefügt" (Finale Herstellung, z.B. Bild in Rahmen, Montage eines Omnibusses)
|
|
|
|
'40', // => Auctioned "wurde versteigert" (Objekt war im Auktionshandel)
|
2020-09-11 11:06:54 +02:00
|
|
|
'41', // "wurde gekauft" (Hier kann man jeden Kauf des Objektes vermerken)
|
|
|
|
'42', // "wurde besessen" (Hier kann man jeden Besitz des Objektes vermerken)
|
|
|
|
'43', // "wurde verkauft" (Hier kann man jeden Verkauf des Objektes vermerken)
|
|
|
|
'44', // "wurde restauriert" (Hier kann man jede Restauierung des Objektes vermerken)
|
|
|
|
'45', // "wurde beschädigt" (Hier kann man jede Beschädigung des Objektes vermerken, Teilbeschädigung oder Anlaß in Ereignisanmerkung)
|
|
|
|
'46', // "wurde zerstört" (Hier kann man die Zerstörung eines Objektes vermerken)
|
|
|
|
'47', // "verschollen" (Hier kann man das Abhandenkommen eines Objektes vermerken)
|
2022-10-13 22:48:16 +02:00
|
|
|
'48', // "wurde herausgegeben"
|
|
|
|
'49', // "gespendet / verschenkt"
|
|
|
|
'50', // "vererbt"
|
2020-09-11 11:06:54 +02:00
|
|
|
|
2020-08-06 17:32:29 +02:00
|
|
|
];
|
|
|
|
|
2023-10-15 13:29:12 +02:00
|
|
|
public const EVENTS_PRODUCTION = [1, 7, 9, 10, 19, 20, 26, 27, 28, 38, 39, 48];
|
2021-10-11 15:11:15 +02:00
|
|
|
|
2020-08-28 23:40:18 +02:00
|
|
|
// Array enthält solche Ereignisse, die nach der Herstellung passiert sein müssen
|
2023-10-15 13:29:12 +02:00
|
|
|
public const EVENTS_POST_PRODUCTION = [2, 3, 6, 8, 11, 13, 14, 15, 32, 34, 37, 40, 41, 42, 43, 44, 45, 46, 47, 49, 50];
|
2021-10-11 15:11:15 +02:00
|
|
|
|
2020-08-28 23:40:18 +02:00
|
|
|
// Array enthält solche Ereignisse, die vor der Herstellung passiert sein müssen
|
2023-10-15 13:29:12 +02:00
|
|
|
public const EVENTS_PRE_PRODUCTION = [4, 12, 25, 29, 30, 31, 35];
|
2021-10-11 15:11:15 +02:00
|
|
|
|
2020-08-28 23:40:18 +02:00
|
|
|
// Array enthält solche Ereignisse, die sich auf Objekte beziehen, die nicht hergestellt wurden
|
2023-10-15 13:29:12 +02:00
|
|
|
public const EVENTS_NO_PRODUCTION = [16, 21, 33];
|
2021-10-11 15:11:15 +02:00
|
|
|
|
2020-10-12 22:54:17 +02:00
|
|
|
// Array enthält Ereignistypen, die auf Korrespondenzen hinweisen
|
2023-10-15 13:29:12 +02:00
|
|
|
public const EVENTS_CORRESPONDENCE = [11, 13];
|
2020-08-28 23:40:18 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Constants for event types without places, times, actors
|
|
|
|
*/
|
2023-10-15 13:29:12 +02:00
|
|
|
public const EVENTS_NO_TIME = [5, 22, 23, 36];
|
|
|
|
public const EVENTS_NO_ACTOR = [21, 22, 24, 36];
|
|
|
|
public const EVENTS_NO_PLACE = [5, 23, 24];
|
2020-08-12 15:51:16 +02:00
|
|
|
|
2020-08-06 17:57:38 +02:00
|
|
|
/**
|
|
|
|
* Gets a list of the entries in a translated version.
|
|
|
|
*
|
|
|
|
* @param MDTlLoader $tlLoader Translation loader.
|
|
|
|
*
|
|
|
|
* @return array<string>
|
|
|
|
*/
|
|
|
|
public static function getSortedList(MDTlLoader $tlLoader):array {
|
2020-08-06 18:42:38 +02:00
|
|
|
return parent::getTlSortedList($tlLoader, self::EVENT_IDS, "eventtype_name", "eventname");
|
2020-08-06 17:57:38 +02:00
|
|
|
|
|
|
|
}
|
2023-10-29 01:27:32 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a list of the entries in a translated version (actor focus).
|
|
|
|
*
|
|
|
|
* @param MDTlLoader $tlLoader Translation loader.
|
|
|
|
*
|
|
|
|
* @return array<string>
|
|
|
|
*/
|
|
|
|
public static function getSortedListActors(MDTlLoader $tlLoader):array {
|
|
|
|
$output = parent::getTlSortedList($tlLoader, self::EVENT_IDS, "eventtype_persinst", "event_persinst");
|
|
|
|
foreach (self::EVENTS_NO_ACTOR as $id) unset($output[$id]);
|
|
|
|
return $output;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a list of the entries in a translated version (place focus).
|
|
|
|
*
|
|
|
|
* @param MDTlLoader $tlLoader Translation loader.
|
|
|
|
*
|
|
|
|
* @return array<string>
|
|
|
|
*/
|
|
|
|
public static function getSortedListPlaces(MDTlLoader $tlLoader):array {
|
|
|
|
$output = parent::getTlSortedList($tlLoader, self::EVENT_IDS, "eventtype_place", "event_place");
|
|
|
|
foreach (self::EVENTS_NO_PLACE as $id) unset($output[$id]);
|
|
|
|
return $output;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a list of the entries in a translated version.
|
|
|
|
*
|
|
|
|
* @param MDTlLoader $tlLoader Translation loader.
|
|
|
|
*
|
|
|
|
* @return array<string>
|
|
|
|
*/
|
|
|
|
public static function getSortedListTimes(MDTlLoader $tlLoader):array {
|
|
|
|
$output = parent::getTlSortedList($tlLoader, self::EVENT_IDS, "eventtype_time", "event_time");
|
|
|
|
foreach (self::EVENTS_NO_TIME as $id) unset($output[$id]);
|
|
|
|
return $output;
|
|
|
|
|
|
|
|
}
|
2020-08-06 17:32:29 +02:00
|
|
|
}
|