@@ -14,121 +14,121 @@ |
||
| 14 | 14 | */ |
| 15 | 15 | class JsonResult |
| 16 | 16 | { |
| 17 | - /** |
|
| 18 | - * @var int |
|
| 19 | - */ |
|
| 20 | - protected $numberOfObjects = 0; |
|
| 21 | - |
|
| 22 | - /** |
|
| 23 | - * @var int |
|
| 24 | - */ |
|
| 25 | - protected $numberOfProcessedObjects = 0; |
|
| 26 | - |
|
| 27 | - /** |
|
| 28 | - * @var array |
|
| 29 | - */ |
|
| 30 | - protected $errorMessages = []; |
|
| 31 | - |
|
| 32 | - /** |
|
| 33 | - * @var array |
|
| 34 | - */ |
|
| 35 | - protected $processedObject = []; |
|
| 36 | - |
|
| 37 | - /** |
|
| 38 | - * @var array |
|
| 39 | - */ |
|
| 40 | - protected $row = null; |
|
| 41 | - |
|
| 42 | - /** |
|
| 43 | - * @return $this |
|
| 44 | - */ |
|
| 45 | - public function incrementNumberOfProcessedObjects() |
|
| 46 | - { |
|
| 47 | - $this->numberOfProcessedObjects++; |
|
| 48 | - } |
|
| 49 | - |
|
| 50 | - /** |
|
| 51 | - * @param string $errorMessages |
|
| 52 | - * @return $this |
|
| 53 | - */ |
|
| 54 | - public function addErrorMessages($errorMessages) |
|
| 55 | - { |
|
| 56 | - if (!empty($errorMessages)) { |
|
| 57 | - $this->errorMessages[] = $errorMessages; |
|
| 58 | - } else { |
|
| 59 | - $this->incrementNumberOfProcessedObjects(); |
|
| 60 | - } |
|
| 61 | - return $this; |
|
| 62 | - } |
|
| 63 | - |
|
| 64 | - /** |
|
| 65 | - * @param array $errorMessages |
|
| 66 | - * @return $this |
|
| 67 | - */ |
|
| 68 | - public function setErrorMessages($errorMessages) |
|
| 69 | - { |
|
| 70 | - $this->errorMessages = $errorMessages; |
|
| 71 | - return $this; |
|
| 72 | - } |
|
| 73 | - |
|
| 74 | - /** |
|
| 75 | - * @param array $processedObject |
|
| 76 | - * @return $this |
|
| 77 | - */ |
|
| 78 | - public function setProcessedObject($processedObject) |
|
| 79 | - { |
|
| 80 | - $this->processedObject = $processedObject; |
|
| 81 | - return $this; |
|
| 82 | - } |
|
| 83 | - |
|
| 84 | - /** |
|
| 85 | - * @return $this |
|
| 86 | - */ |
|
| 87 | - public function hasErrors() |
|
| 88 | - { |
|
| 89 | - return !empty($this->errorMessages); |
|
| 90 | - } |
|
| 91 | - |
|
| 92 | - /** |
|
| 93 | - * @param mixed $numberOfObjects |
|
| 94 | - * @return $this |
|
| 95 | - */ |
|
| 96 | - public function setNumberOfObjects($numberOfObjects) |
|
| 97 | - { |
|
| 98 | - $this->numberOfObjects = $numberOfObjects; |
|
| 99 | - return $this; |
|
| 100 | - } |
|
| 101 | - |
|
| 102 | - /** |
|
| 103 | - * @param mixed $row |
|
| 104 | - * @return $this |
|
| 105 | - */ |
|
| 106 | - public function setRow(array $row) |
|
| 107 | - { |
|
| 108 | - $this->row = $row; |
|
| 109 | - return $this; |
|
| 110 | - } |
|
| 111 | - |
|
| 112 | - /** |
|
| 113 | - * Convert $this to array |
|
| 114 | - * |
|
| 115 | - * @return array |
|
| 116 | - */ |
|
| 117 | - public function toArray() |
|
| 118 | - { |
|
| 119 | - $arrayValues = array( |
|
| 120 | - 'numberOfObjects' => $this->numberOfObjects, |
|
| 121 | - 'numberOfProcessedObjects' => $this->numberOfProcessedObjects, |
|
| 122 | - 'hasErrors' => $this->hasErrors(), |
|
| 123 | - 'errorMessages' => $this->errorMessages, |
|
| 124 | - 'row' => $this->row, |
|
| 125 | - ); |
|
| 126 | - |
|
| 127 | - // Only feed key processedObject if it has values. |
|
| 128 | - if (!empty($this->processedObject)) { |
|
| 129 | - $arrayValues['processedObject'] = $this->processedObject; |
|
| 130 | - } |
|
| 131 | - |
|
| 132 | - return $arrayValues; |
|
| 133 | - } |
|
| 17 | + /** |
|
| 18 | + * @var int |
|
| 19 | + */ |
|
| 20 | + protected $numberOfObjects = 0; |
|
| 21 | + |
|
| 22 | + /** |
|
| 23 | + * @var int |
|
| 24 | + */ |
|
| 25 | + protected $numberOfProcessedObjects = 0; |
|
| 26 | + |
|
| 27 | + /** |
|
| 28 | + * @var array |
|
| 29 | + */ |
|
| 30 | + protected $errorMessages = []; |
|
| 31 | + |
|
| 32 | + /** |
|
| 33 | + * @var array |
|
| 34 | + */ |
|
| 35 | + protected $processedObject = []; |
|
| 36 | + |
|
| 37 | + /** |
|
| 38 | + * @var array |
|
| 39 | + */ |
|
| 40 | + protected $row = null; |
|
| 41 | + |
|
| 42 | + /** |
|
| 43 | + * @return $this |
|
| 44 | + */ |
|
| 45 | + public function incrementNumberOfProcessedObjects() |
|
| 46 | + { |
|
| 47 | + $this->numberOfProcessedObjects++; |
|
| 48 | + } |
|
| 49 | + |
|
| 50 | + /** |
|
| 51 | + * @param string $errorMessages |
|
| 52 | + * @return $this |
|
| 53 | + */ |
|
| 54 | + public function addErrorMessages($errorMessages) |
|
| 55 | + { |
|
| 56 | + if (!empty($errorMessages)) { |
|
| 57 | + $this->errorMessages[] = $errorMessages; |
|
| 58 | + } else { |
|
| 59 | + $this->incrementNumberOfProcessedObjects(); |
|
| 60 | + } |
|
| 61 | + return $this; |
|
| 62 | + } |
|
| 63 | + |
|
| 64 | + /** |
|
| 65 | + * @param array $errorMessages |
|
| 66 | + * @return $this |
|
| 67 | + */ |
|
| 68 | + public function setErrorMessages($errorMessages) |
|
| 69 | + { |
|
| 70 | + $this->errorMessages = $errorMessages; |
|
| 71 | + return $this; |
|
| 72 | + } |
|
| 73 | + |
|
| 74 | + /** |
|
| 75 | + * @param array $processedObject |
|
| 76 | + * @return $this |
|
| 77 | + */ |
|
| 78 | + public function setProcessedObject($processedObject) |
|
| 79 | + { |
|
| 80 | + $this->processedObject = $processedObject; |
|
| 81 | + return $this; |
|
| 82 | + } |
|
| 83 | + |
|
| 84 | + /** |
|
| 85 | + * @return $this |
|
| 86 | + */ |
|
| 87 | + public function hasErrors() |
|
| 88 | + { |
|
| 89 | + return !empty($this->errorMessages); |
|
| 90 | + } |
|
| 91 | + |
|
| 92 | + /** |
|
| 93 | + * @param mixed $numberOfObjects |
|
| 94 | + * @return $this |
|
| 95 | + */ |
|
| 96 | + public function setNumberOfObjects($numberOfObjects) |
|
| 97 | + { |
|
| 98 | + $this->numberOfObjects = $numberOfObjects; |
|
| 99 | + return $this; |
|
| 100 | + } |
|
| 101 | + |
|
| 102 | + /** |
|
| 103 | + * @param mixed $row |
|
| 104 | + * @return $this |
|
| 105 | + */ |
|
| 106 | + public function setRow(array $row) |
|
| 107 | + { |
|
| 108 | + $this->row = $row; |
|
| 109 | + return $this; |
|
| 110 | + } |
|
| 111 | + |
|
| 112 | + /** |
|
| 113 | + * Convert $this to array |
|
| 114 | + * |
|
| 115 | + * @return array |
|
| 116 | + */ |
|
| 117 | + public function toArray() |
|
| 118 | + { |
|
| 119 | + $arrayValues = array( |
|
| 120 | + 'numberOfObjects' => $this->numberOfObjects, |
|
| 121 | + 'numberOfProcessedObjects' => $this->numberOfProcessedObjects, |
|
| 122 | + 'hasErrors' => $this->hasErrors(), |
|
| 123 | + 'errorMessages' => $this->errorMessages, |
|
| 124 | + 'row' => $this->row, |
|
| 125 | + ); |
|
| 126 | + |
|
| 127 | + // Only feed key processedObject if it has values. |
|
| 128 | + if (!empty($this->processedObject)) { |
|
| 129 | + $arrayValues['processedObject'] = $this->processedObject; |
|
| 130 | + } |
|
| 131 | + |
|
| 132 | + return $arrayValues; |
|
| 133 | + } |
|
| 134 | 134 | } |
@@ -20,163 +20,163 @@ |
||
| 20 | 20 | */ |
| 21 | 21 | class LanguageService implements SingletonInterface |
| 22 | 22 | { |
| 23 | - /** |
|
| 24 | - * @var array |
|
| 25 | - */ |
|
| 26 | - protected $languages; |
|
| 27 | - |
|
| 28 | - /** |
|
| 29 | - * @var array |
|
| 30 | - */ |
|
| 31 | - protected $defaultIcon; |
|
| 32 | - |
|
| 33 | - /** |
|
| 34 | - * Store the localized records to boost up performance. |
|
| 35 | - * |
|
| 36 | - * @var array |
|
| 37 | - */ |
|
| 38 | - protected $localizedRecordStorage; |
|
| 39 | - |
|
| 40 | - /** |
|
| 41 | - * Returns available language records. |
|
| 42 | - * The method stores the records in the property to speed up the process as the method can be often called. |
|
| 43 | - * |
|
| 44 | - * @return array |
|
| 45 | - */ |
|
| 46 | - public function getLanguages() |
|
| 47 | - { |
|
| 48 | - if ($this->languages === null) { |
|
| 49 | - $this->languages = $this->getDataService()->getRecords('sys_language'); |
|
| 50 | - } |
|
| 51 | - return $this->languages; |
|
| 52 | - } |
|
| 53 | - |
|
| 54 | - /** |
|
| 55 | - * Returns a localized record according to a Content object and a language identifier. |
|
| 56 | - * Notice! This method does not overlay anything but simply returns the raw localized record. |
|
| 57 | - * |
|
| 58 | - * @param Content $object |
|
| 59 | - * @param int $language |
|
| 60 | - * @return Content |
|
| 61 | - */ |
|
| 62 | - public function getLocalizedContent(Content $object, $language) |
|
| 63 | - { |
|
| 64 | - // We want to cache data per Content object. Retrieve the Object hash. |
|
| 65 | - $objectHash = spl_object_hash($object); |
|
| 66 | - |
|
| 67 | - // Initialize the storage |
|
| 68 | - if (empty($this->localizedRecordStorage[$objectHash])) { |
|
| 69 | - $this->localizedRecordStorage[$objectHash] = []; |
|
| 70 | - } |
|
| 71 | - |
|
| 72 | - if (empty($this->localizedRecordStorage[$objectHash][$language])) { |
|
| 73 | - $localizedRecord = $this->getDataService()->getRecord( |
|
| 74 | - $object->getDataType(), |
|
| 75 | - [ |
|
| 76 | - Tca::table($object)->getLanguageParentField() => $object->getUid(), // e.g. l10n_parent |
|
| 77 | - Tca::table($object)->getLanguageField() => $language, // e.g. sys_language_uid |
|
| 78 | - ] |
|
| 79 | - ); |
|
| 80 | - |
|
| 81 | - if ($localizedRecord) { |
|
| 82 | - $localizedContent = GeneralUtility::makeInstance(Content::class, $object->getDataType(), $localizedRecord); |
|
| 83 | - $this->localizedRecordStorage[$objectHash][$language] = $localizedContent; |
|
| 84 | - } else { |
|
| 85 | - $this->localizedRecordStorage[$objectHash][$language] = []; // We want an array at least, even if empty. |
|
| 86 | - } |
|
| 87 | - } |
|
| 88 | - |
|
| 89 | - return $this->localizedRecordStorage[$objectHash][$language]; |
|
| 90 | - } |
|
| 91 | - |
|
| 92 | - /** |
|
| 93 | - * Tell whether the given Content object has a localization. |
|
| 94 | - * |
|
| 95 | - * @param Content $object |
|
| 96 | - * @param int $language |
|
| 97 | - * @return string |
|
| 98 | - */ |
|
| 99 | - public function hasLocalization(Content $object, $language) |
|
| 100 | - { |
|
| 101 | - $localizedRecord = $this->getLocalizedContent($object, $language); |
|
| 102 | - return !empty($localizedRecord); |
|
| 103 | - } |
|
| 104 | - |
|
| 105 | - /** |
|
| 106 | - * Returns a localized field according to a Content object and a language identifier. |
|
| 107 | - * Notice! If there is not translation, simply returns an empty string. |
|
| 108 | - * |
|
| 109 | - * @param Content $object |
|
| 110 | - * @param int $language |
|
| 111 | - * @param string $fieldName |
|
| 112 | - * @return string |
|
| 113 | - */ |
|
| 114 | - public function getLocalizedFieldName(Content $object, $language, $fieldName) |
|
| 115 | - { |
|
| 116 | - $localizedRecord = $this->getLocalizedContent($object, $language); |
|
| 117 | - return empty($localizedRecord) ? '' : $localizedRecord[$fieldName]; |
|
| 118 | - } |
|
| 119 | - |
|
| 120 | - /** |
|
| 121 | - * Returns the default language configured by TSConfig. |
|
| 122 | - * |
|
| 123 | - * @return array |
|
| 124 | - */ |
|
| 125 | - public function getDefaultFlag() |
|
| 126 | - { |
|
| 127 | - if ($this->defaultIcon === null) { |
|
| 128 | - $defaultFlag = ''; // default value |
|
| 129 | - |
|
| 130 | - $tsConfig = BackendUtility::getPagesTSconfig(0, 'mod.SHARED'); |
|
| 131 | - |
|
| 132 | - // Fallback non sprite-configuration |
|
| 133 | - if (($pos = strrpos($tsConfig['properties']['defaultLanguageFlag'], '.')) !== false) { |
|
| 134 | - $defaultFlag = substr($tsConfig['properties']['defaultLanguageFlag'], 0, $pos); |
|
| 135 | - } |
|
| 136 | - |
|
| 137 | - $this->defaultIcon = $defaultFlag; |
|
| 138 | - } |
|
| 139 | - |
|
| 140 | - return $this->defaultIcon; |
|
| 141 | - } |
|
| 142 | - |
|
| 143 | - /** |
|
| 144 | - * Returns whether the system includes language records. |
|
| 145 | - * |
|
| 146 | - * @return bool |
|
| 147 | - */ |
|
| 148 | - public function hasLanguages() |
|
| 149 | - { |
|
| 150 | - $languages = $this->getLanguages(); |
|
| 151 | - return !empty($languages); |
|
| 152 | - } |
|
| 153 | - |
|
| 154 | - /** |
|
| 155 | - * Tell whether the given language exists. |
|
| 156 | - * |
|
| 157 | - * @param int $language |
|
| 158 | - * @return bool |
|
| 159 | - */ |
|
| 160 | - public function languageExists($language) |
|
| 161 | - { |
|
| 162 | - $languages = $this->getLanguages(); |
|
| 163 | - |
|
| 164 | - $LanguageExists = false; |
|
| 165 | - foreach ($languages as $_language) { |
|
| 166 | - if ((int)$_language['uid'] === (int)$language) { |
|
| 167 | - $LanguageExists = true; |
|
| 168 | - break; |
|
| 169 | - } |
|
| 170 | - } |
|
| 171 | - |
|
| 172 | - return $LanguageExists; |
|
| 173 | - } |
|
| 174 | - |
|
| 175 | - /** |
|
| 176 | - * @return object|DataService |
|
| 177 | - */ |
|
| 178 | - protected function getDataService(): DataService |
|
| 179 | - { |
|
| 180 | - return GeneralUtility::makeInstance(DataService::class); |
|
| 181 | - } |
|
| 23 | + /** |
|
| 24 | + * @var array |
|
| 25 | + */ |
|
| 26 | + protected $languages; |
|
| 27 | + |
|
| 28 | + /** |
|
| 29 | + * @var array |
|
| 30 | + */ |
|
| 31 | + protected $defaultIcon; |
|
| 32 | + |
|
| 33 | + /** |
|
| 34 | + * Store the localized records to boost up performance. |
|
| 35 | + * |
|
| 36 | + * @var array |
|
| 37 | + */ |
|
| 38 | + protected $localizedRecordStorage; |
|
| 39 | + |
|
| 40 | + /** |
|
| 41 | + * Returns available language records. |
|
| 42 | + * The method stores the records in the property to speed up the process as the method can be often called. |
|
| 43 | + * |
|
| 44 | + * @return array |
|
| 45 | + */ |
|
| 46 | + public function getLanguages() |
|
| 47 | + { |
|
| 48 | + if ($this->languages === null) { |
|
| 49 | + $this->languages = $this->getDataService()->getRecords('sys_language'); |
|
| 50 | + } |
|
| 51 | + return $this->languages; |
|
| 52 | + } |
|
| 53 | + |
|
| 54 | + /** |
|
| 55 | + * Returns a localized record according to a Content object and a language identifier. |
|
| 56 | + * Notice! This method does not overlay anything but simply returns the raw localized record. |
|
| 57 | + * |
|
| 58 | + * @param Content $object |
|
| 59 | + * @param int $language |
|
| 60 | + * @return Content |
|
| 61 | + */ |
|
| 62 | + public function getLocalizedContent(Content $object, $language) |
|
| 63 | + { |
|
| 64 | + // We want to cache data per Content object. Retrieve the Object hash. |
|
| 65 | + $objectHash = spl_object_hash($object); |
|
| 66 | + |
|
| 67 | + // Initialize the storage |
|
| 68 | + if (empty($this->localizedRecordStorage[$objectHash])) { |
|
| 69 | + $this->localizedRecordStorage[$objectHash] = []; |
|
| 70 | + } |
|
| 71 | + |
|
| 72 | + if (empty($this->localizedRecordStorage[$objectHash][$language])) { |
|
| 73 | + $localizedRecord = $this->getDataService()->getRecord( |
|
| 74 | + $object->getDataType(), |
|
| 75 | + [ |
|
| 76 | + Tca::table($object)->getLanguageParentField() => $object->getUid(), // e.g. l10n_parent |
|
| 77 | + Tca::table($object)->getLanguageField() => $language, // e.g. sys_language_uid |
|
| 78 | + ] |
|
| 79 | + ); |
|
| 80 | + |
|
| 81 | + if ($localizedRecord) { |
|
| 82 | + $localizedContent = GeneralUtility::makeInstance(Content::class, $object->getDataType(), $localizedRecord); |
|
| 83 | + $this->localizedRecordStorage[$objectHash][$language] = $localizedContent; |
|
| 84 | + } else { |
|
| 85 | + $this->localizedRecordStorage[$objectHash][$language] = []; // We want an array at least, even if empty. |
|
| 86 | + } |
|
| 87 | + } |
|
| 88 | + |
|
| 89 | + return $this->localizedRecordStorage[$objectHash][$language]; |
|
| 90 | + } |
|
| 91 | + |
|
| 92 | + /** |
|
| 93 | + * Tell whether the given Content object has a localization. |
|
| 94 | + * |
|
| 95 | + * @param Content $object |
|
| 96 | + * @param int $language |
|
| 97 | + * @return string |
|
| 98 | + */ |
|
| 99 | + public function hasLocalization(Content $object, $language) |
|
| 100 | + { |
|
| 101 | + $localizedRecord = $this->getLocalizedContent($object, $language); |
|
| 102 | + return !empty($localizedRecord); |
|
| 103 | + } |
|
| 104 | + |
|
| 105 | + /** |
|
| 106 | + * Returns a localized field according to a Content object and a language identifier. |
|
| 107 | + * Notice! If there is not translation, simply returns an empty string. |
|
| 108 | + * |
|
| 109 | + * @param Content $object |
|
| 110 | + * @param int $language |
|
| 111 | + * @param string $fieldName |
|
| 112 | + * @return string |
|
| 113 | + */ |
|
| 114 | + public function getLocalizedFieldName(Content $object, $language, $fieldName) |
|
| 115 | + { |
|
| 116 | + $localizedRecord = $this->getLocalizedContent($object, $language); |
|
| 117 | + return empty($localizedRecord) ? '' : $localizedRecord[$fieldName]; |
|
| 118 | + } |
|
| 119 | + |
|
| 120 | + /** |
|
| 121 | + * Returns the default language configured by TSConfig. |
|
| 122 | + * |
|
| 123 | + * @return array |
|
| 124 | + */ |
|
| 125 | + public function getDefaultFlag() |
|
| 126 | + { |
|
| 127 | + if ($this->defaultIcon === null) { |
|
| 128 | + $defaultFlag = ''; // default value |
|
| 129 | + |
|
| 130 | + $tsConfig = BackendUtility::getPagesTSconfig(0, 'mod.SHARED'); |
|
| 131 | + |
|
| 132 | + // Fallback non sprite-configuration |
|
| 133 | + if (($pos = strrpos($tsConfig['properties']['defaultLanguageFlag'], '.')) !== false) { |
|
| 134 | + $defaultFlag = substr($tsConfig['properties']['defaultLanguageFlag'], 0, $pos); |
|
| 135 | + } |
|
| 136 | + |
|
| 137 | + $this->defaultIcon = $defaultFlag; |
|
| 138 | + } |
|
| 139 | + |
|
| 140 | + return $this->defaultIcon; |
|
| 141 | + } |
|
| 142 | + |
|
| 143 | + /** |
|
| 144 | + * Returns whether the system includes language records. |
|
| 145 | + * |
|
| 146 | + * @return bool |
|
| 147 | + */ |
|
| 148 | + public function hasLanguages() |
|
| 149 | + { |
|
| 150 | + $languages = $this->getLanguages(); |
|
| 151 | + return !empty($languages); |
|
| 152 | + } |
|
| 153 | + |
|
| 154 | + /** |
|
| 155 | + * Tell whether the given language exists. |
|
| 156 | + * |
|
| 157 | + * @param int $language |
|
| 158 | + * @return bool |
|
| 159 | + */ |
|
| 160 | + public function languageExists($language) |
|
| 161 | + { |
|
| 162 | + $languages = $this->getLanguages(); |
|
| 163 | + |
|
| 164 | + $LanguageExists = false; |
|
| 165 | + foreach ($languages as $_language) { |
|
| 166 | + if ((int)$_language['uid'] === (int)$language) { |
|
| 167 | + $LanguageExists = true; |
|
| 168 | + break; |
|
| 169 | + } |
|
| 170 | + } |
|
| 171 | + |
|
| 172 | + return $LanguageExists; |
|
| 173 | + } |
|
| 174 | + |
|
| 175 | + /** |
|
| 176 | + * @return object|DataService |
|
| 177 | + */ |
|
| 178 | + protected function getDataService(): DataService |
|
| 179 | + { |
|
| 180 | + return GeneralUtility::makeInstance(DataService::class); |
|
| 181 | + } |
|
| 182 | 182 | } |
@@ -16,7 +16,7 @@ |
||
| 16 | 16 | */ |
| 17 | 17 | class LocalizationStatus extends Enumeration |
| 18 | 18 | { |
| 19 | - public const LOCALIZED = 'localized'; |
|
| 20 | - public const NOT_YET_LOCALIZED = 'notYetLocalized'; |
|
| 21 | - public const EMPTY_VALUE = 'emptyValue'; |
|
| 19 | + public const LOCALIZED = 'localized'; |
|
| 20 | + public const NOT_YET_LOCALIZED = 'notYetLocalized'; |
|
| 21 | + public const EMPTY_VALUE = 'emptyValue'; |
|
| 22 | 22 | } |
@@ -22,162 +22,162 @@ |
||
| 22 | 22 | */ |
| 23 | 23 | class PageFacet implements FacetInterface |
| 24 | 24 | { |
| 25 | - /** |
|
| 26 | - * @var string |
|
| 27 | - */ |
|
| 28 | - protected $name; |
|
| 29 | - |
|
| 30 | - /** |
|
| 31 | - * @var string |
|
| 32 | - */ |
|
| 33 | - protected $label; |
|
| 34 | - |
|
| 35 | - /** |
|
| 36 | - * @var string |
|
| 37 | - */ |
|
| 38 | - protected $dataType; |
|
| 39 | - |
|
| 40 | - /** |
|
| 41 | - * @var bool |
|
| 42 | - */ |
|
| 43 | - protected $canModifyMatcher = false; |
|
| 44 | - |
|
| 45 | - /** |
|
| 46 | - * Constructor of a Generic Facet in Vidi. |
|
| 47 | - * |
|
| 48 | - * @param string $name |
|
| 49 | - * @param string $label |
|
| 50 | - */ |
|
| 51 | - public function __construct($name, $label = '') |
|
| 52 | - { |
|
| 53 | - $this->name = 'pid'; |
|
| 54 | - $this->label = $label; |
|
| 55 | - } |
|
| 56 | - |
|
| 57 | - /** |
|
| 58 | - * @return string |
|
| 59 | - */ |
|
| 60 | - public function getName(): string |
|
| 61 | - { |
|
| 62 | - return $this->name; |
|
| 63 | - } |
|
| 64 | - |
|
| 65 | - /** |
|
| 66 | - * @return string |
|
| 67 | - */ |
|
| 68 | - public function getLabel(): string |
|
| 69 | - { |
|
| 70 | - return $this->label; |
|
| 71 | - } |
|
| 72 | - |
|
| 73 | - /** |
|
| 74 | - * @return array |
|
| 75 | - */ |
|
| 76 | - public function getSuggestions(): array |
|
| 77 | - { |
|
| 78 | - $values = []; |
|
| 79 | - foreach ($this->getStoragePages() as $page) { |
|
| 80 | - $values[] = [ |
|
| 81 | - $page['uid'] => sprintf('%s (%s)', $page['title'], $page['uid']) |
|
| 82 | - ]; |
|
| 83 | - } |
|
| 84 | - return $values; |
|
| 85 | - } |
|
| 86 | - |
|
| 87 | - /** |
|
| 88 | - * @return array |
|
| 89 | - */ |
|
| 90 | - protected function getStoragePages(): array |
|
| 91 | - { |
|
| 92 | - /** @var QueryBuilder $query */ |
|
| 93 | - $query = $this->getQueryBuilder('pages'); |
|
| 94 | - $query->getRestrictions()->removeAll(); |
|
| 95 | - return $query->select('*') |
|
| 96 | - ->from('pages') |
|
| 97 | - ->where( |
|
| 98 | - sprintf( |
|
| 99 | - 'uid IN (SELECT DISTINCT(pid) FROM %s WHERE 1=1 %s)', |
|
| 100 | - $this->getModuleLoader()->getDataType(), |
|
| 101 | - BackendUtility::deleteClause( |
|
| 102 | - $this->getModuleLoader()->getDataType() |
|
| 103 | - ) |
|
| 104 | - ), |
|
| 105 | - BackendUtility::deleteClause('pages', '') |
|
| 106 | - ) |
|
| 107 | - ->execute() |
|
| 108 | - ->fetchAllAssociative(); |
|
| 109 | - } |
|
| 110 | - |
|
| 111 | - /** |
|
| 112 | - * @param string $tableName |
|
| 113 | - * @return object|QueryBuilder |
|
| 114 | - */ |
|
| 115 | - protected function getQueryBuilder($tableName): QueryBuilder |
|
| 116 | - { |
|
| 117 | - /** @var ConnectionPool $connectionPool */ |
|
| 118 | - $connectionPool = GeneralUtility::makeInstance(ConnectionPool::class); |
|
| 119 | - return $connectionPool->getQueryBuilderForTable($tableName); |
|
| 120 | - } |
|
| 121 | - |
|
| 122 | - /** |
|
| 123 | - * @return LanguageService |
|
| 124 | - */ |
|
| 125 | - protected function getLanguageService(): LanguageService |
|
| 126 | - { |
|
| 127 | - /** @var LanguageService $langService */ |
|
| 128 | - $langService = $GLOBALS['LANG']; |
|
| 129 | - if (!$langService) { |
|
| 130 | - $langService = GeneralUtility::makeInstance(LanguageService::class); |
|
| 131 | - $langService->init('en'); |
|
| 132 | - } |
|
| 133 | - |
|
| 134 | - return $langService; |
|
| 135 | - } |
|
| 136 | - |
|
| 137 | - /** |
|
| 138 | - * @return bool |
|
| 139 | - */ |
|
| 140 | - public function hasSuggestions(): bool |
|
| 141 | - { |
|
| 142 | - return true; |
|
| 143 | - } |
|
| 144 | - |
|
| 145 | - /** |
|
| 146 | - * @param string $dataType |
|
| 147 | - * @return $this |
|
| 148 | - */ |
|
| 149 | - public function setDataType($dataType): self |
|
| 150 | - { |
|
| 151 | - $this->dataType = $dataType; |
|
| 152 | - return $this; |
|
| 153 | - } |
|
| 154 | - |
|
| 155 | - /** |
|
| 156 | - * @return bool |
|
| 157 | - */ |
|
| 158 | - public function canModifyMatcher(): bool |
|
| 159 | - { |
|
| 160 | - return $this->canModifyMatcher; |
|
| 161 | - } |
|
| 162 | - |
|
| 163 | - /** |
|
| 164 | - * @param Matcher $matcher |
|
| 165 | - * @param $value |
|
| 166 | - * @return Matcher |
|
| 167 | - */ |
|
| 168 | - public function modifyMatcher(Matcher $matcher, $value): Matcher |
|
| 169 | - { |
|
| 170 | - return $matcher; |
|
| 171 | - } |
|
| 172 | - |
|
| 173 | - /** |
|
| 174 | - * Get the Vidi Module Loader. |
|
| 175 | - * |
|
| 176 | - * @return ModuleLoader|object |
|
| 177 | - * @throws \InvalidArgumentException |
|
| 178 | - */ |
|
| 179 | - protected function getModuleLoader() |
|
| 180 | - { |
|
| 181 | - return GeneralUtility::makeInstance(ModuleLoader::class); |
|
| 182 | - } |
|
| 25 | + /** |
|
| 26 | + * @var string |
|
| 27 | + */ |
|
| 28 | + protected $name; |
|
| 29 | + |
|
| 30 | + /** |
|
| 31 | + * @var string |
|
| 32 | + */ |
|
| 33 | + protected $label; |
|
| 34 | + |
|
| 35 | + /** |
|
| 36 | + * @var string |
|
| 37 | + */ |
|
| 38 | + protected $dataType; |
|
| 39 | + |
|
| 40 | + /** |
|
| 41 | + * @var bool |
|
| 42 | + */ |
|
| 43 | + protected $canModifyMatcher = false; |
|
| 44 | + |
|
| 45 | + /** |
|
| 46 | + * Constructor of a Generic Facet in Vidi. |
|
| 47 | + * |
|
| 48 | + * @param string $name |
|
| 49 | + * @param string $label |
|
| 50 | + */ |
|
| 51 | + public function __construct($name, $label = '') |
|
| 52 | + { |
|
| 53 | + $this->name = 'pid'; |
|
| 54 | + $this->label = $label; |
|
| 55 | + } |
|
| 56 | + |
|
| 57 | + /** |
|
| 58 | + * @return string |
|
| 59 | + */ |
|
| 60 | + public function getName(): string |
|
| 61 | + { |
|
| 62 | + return $this->name; |
|
| 63 | + } |
|
| 64 | + |
|
| 65 | + /** |
|
| 66 | + * @return string |
|
| 67 | + */ |
|
| 68 | + public function getLabel(): string |
|
| 69 | + { |
|
| 70 | + return $this->label; |
|
| 71 | + } |
|
| 72 | + |
|
| 73 | + /** |
|
| 74 | + * @return array |
|
| 75 | + */ |
|
| 76 | + public function getSuggestions(): array |
|
| 77 | + { |
|
| 78 | + $values = []; |
|
| 79 | + foreach ($this->getStoragePages() as $page) { |
|
| 80 | + $values[] = [ |
|
| 81 | + $page['uid'] => sprintf('%s (%s)', $page['title'], $page['uid']) |
|
| 82 | + ]; |
|
| 83 | + } |
|
| 84 | + return $values; |
|
| 85 | + } |
|
| 86 | + |
|
| 87 | + /** |
|
| 88 | + * @return array |
|
| 89 | + */ |
|
| 90 | + protected function getStoragePages(): array |
|
| 91 | + { |
|
| 92 | + /** @var QueryBuilder $query */ |
|
| 93 | + $query = $this->getQueryBuilder('pages'); |
|
| 94 | + $query->getRestrictions()->removeAll(); |
|
| 95 | + return $query->select('*') |
|
| 96 | + ->from('pages') |
|
| 97 | + ->where( |
|
| 98 | + sprintf( |
|
| 99 | + 'uid IN (SELECT DISTINCT(pid) FROM %s WHERE 1=1 %s)', |
|
| 100 | + $this->getModuleLoader()->getDataType(), |
|
| 101 | + BackendUtility::deleteClause( |
|
| 102 | + $this->getModuleLoader()->getDataType() |
|
| 103 | + ) |
|
| 104 | + ), |
|
| 105 | + BackendUtility::deleteClause('pages', '') |
|
| 106 | + ) |
|
| 107 | + ->execute() |
|
| 108 | + ->fetchAllAssociative(); |
|
| 109 | + } |
|
| 110 | + |
|
| 111 | + /** |
|
| 112 | + * @param string $tableName |
|
| 113 | + * @return object|QueryBuilder |
|
| 114 | + */ |
|
| 115 | + protected function getQueryBuilder($tableName): QueryBuilder |
|
| 116 | + { |
|
| 117 | + /** @var ConnectionPool $connectionPool */ |
|
| 118 | + $connectionPool = GeneralUtility::makeInstance(ConnectionPool::class); |
|
| 119 | + return $connectionPool->getQueryBuilderForTable($tableName); |
|
| 120 | + } |
|
| 121 | + |
|
| 122 | + /** |
|
| 123 | + * @return LanguageService |
|
| 124 | + */ |
|
| 125 | + protected function getLanguageService(): LanguageService |
|
| 126 | + { |
|
| 127 | + /** @var LanguageService $langService */ |
|
| 128 | + $langService = $GLOBALS['LANG']; |
|
| 129 | + if (!$langService) { |
|
| 130 | + $langService = GeneralUtility::makeInstance(LanguageService::class); |
|
| 131 | + $langService->init('en'); |
|
| 132 | + } |
|
| 133 | + |
|
| 134 | + return $langService; |
|
| 135 | + } |
|
| 136 | + |
|
| 137 | + /** |
|
| 138 | + * @return bool |
|
| 139 | + */ |
|
| 140 | + public function hasSuggestions(): bool |
|
| 141 | + { |
|
| 142 | + return true; |
|
| 143 | + } |
|
| 144 | + |
|
| 145 | + /** |
|
| 146 | + * @param string $dataType |
|
| 147 | + * @return $this |
|
| 148 | + */ |
|
| 149 | + public function setDataType($dataType): self |
|
| 150 | + { |
|
| 151 | + $this->dataType = $dataType; |
|
| 152 | + return $this; |
|
| 153 | + } |
|
| 154 | + |
|
| 155 | + /** |
|
| 156 | + * @return bool |
|
| 157 | + */ |
|
| 158 | + public function canModifyMatcher(): bool |
|
| 159 | + { |
|
| 160 | + return $this->canModifyMatcher; |
|
| 161 | + } |
|
| 162 | + |
|
| 163 | + /** |
|
| 164 | + * @param Matcher $matcher |
|
| 165 | + * @param $value |
|
| 166 | + * @return Matcher |
|
| 167 | + */ |
|
| 168 | + public function modifyMatcher(Matcher $matcher, $value): Matcher |
|
| 169 | + { |
|
| 170 | + return $matcher; |
|
| 171 | + } |
|
| 172 | + |
|
| 173 | + /** |
|
| 174 | + * Get the Vidi Module Loader. |
|
| 175 | + * |
|
| 176 | + * @return ModuleLoader|object |
|
| 177 | + * @throws \InvalidArgumentException |
|
| 178 | + */ |
|
| 179 | + protected function getModuleLoader() |
|
| 180 | + { |
|
| 181 | + return GeneralUtility::makeInstance(ModuleLoader::class); |
|
| 182 | + } |
|
| 183 | 183 | } |
@@ -20,142 +20,142 @@ |
||
| 20 | 20 | */ |
| 21 | 21 | class StandardFacet implements FacetInterface |
| 22 | 22 | { |
| 23 | - /** |
|
| 24 | - * @var string |
|
| 25 | - */ |
|
| 26 | - protected $name; |
|
| 27 | - |
|
| 28 | - /** |
|
| 29 | - * @var string |
|
| 30 | - */ |
|
| 31 | - protected $label; |
|
| 32 | - |
|
| 33 | - /** |
|
| 34 | - * @var array |
|
| 35 | - */ |
|
| 36 | - protected $suggestions = []; |
|
| 37 | - |
|
| 38 | - /** |
|
| 39 | - * @var string |
|
| 40 | - */ |
|
| 41 | - protected $dataType; |
|
| 42 | - |
|
| 43 | - /** |
|
| 44 | - * @var bool |
|
| 45 | - */ |
|
| 46 | - protected $canModifyMatcher = false; |
|
| 47 | - |
|
| 48 | - /** |
|
| 49 | - * Constructor of a Generic Facet in Vidi. |
|
| 50 | - * |
|
| 51 | - * @param string $name |
|
| 52 | - * @param string $label |
|
| 53 | - * @param array $suggestions |
|
| 54 | - */ |
|
| 55 | - public function __construct($name, $label = '', array $suggestions = []) |
|
| 56 | - { |
|
| 57 | - $this->name = $name; |
|
| 58 | - if (empty($label)) { |
|
| 59 | - $label = $this->name; |
|
| 60 | - } |
|
| 61 | - $this->label = $label; |
|
| 62 | - $this->suggestions = $suggestions; |
|
| 63 | - } |
|
| 64 | - |
|
| 65 | - /** |
|
| 66 | - * @return string |
|
| 67 | - */ |
|
| 68 | - public function getName(): string |
|
| 69 | - { |
|
| 70 | - return $this->name; |
|
| 71 | - } |
|
| 72 | - |
|
| 73 | - /** |
|
| 74 | - * @return string |
|
| 75 | - */ |
|
| 76 | - public function getLabel(): string |
|
| 77 | - { |
|
| 78 | - if ($this->label === $this->name) { |
|
| 79 | - $label = Tca::table($this->dataType)->field($this->getName())->getLabel(); |
|
| 80 | - } else { |
|
| 81 | - try { |
|
| 82 | - $label = LocalizationUtility::translate($this->label, ''); |
|
| 83 | - } catch (\InvalidArgumentException $e) { |
|
| 84 | - } |
|
| 85 | - if (empty($label)) { |
|
| 86 | - $label = $this->label; |
|
| 87 | - } |
|
| 88 | - } |
|
| 89 | - |
|
| 90 | - return $label; |
|
| 91 | - } |
|
| 92 | - |
|
| 93 | - /** |
|
| 94 | - * @return array |
|
| 95 | - */ |
|
| 96 | - public function getSuggestions(): array |
|
| 97 | - { |
|
| 98 | - $values = []; |
|
| 99 | - foreach ($this->suggestions as $key => $label) { |
|
| 100 | - $localizedLabel = $this->getLanguageService()->sL($label); |
|
| 101 | - if (!empty($localizedLabel)) { |
|
| 102 | - $label = $localizedLabel; |
|
| 103 | - } |
|
| 104 | - |
|
| 105 | - $values[] = [$key => $label]; |
|
| 106 | - } |
|
| 107 | - |
|
| 108 | - return $values; |
|
| 109 | - } |
|
| 110 | - |
|
| 111 | - /** |
|
| 112 | - * @return LanguageService |
|
| 113 | - */ |
|
| 114 | - protected function getLanguageService(): LanguageService |
|
| 115 | - { |
|
| 116 | - /** @var LanguageService $langService */ |
|
| 117 | - $langService = $GLOBALS['LANG']; |
|
| 118 | - if (!$langService) { |
|
| 119 | - $langService = GeneralUtility::makeInstance(LanguageService::class); |
|
| 120 | - $langService->init('en'); |
|
| 121 | - } |
|
| 122 | - |
|
| 123 | - return $langService; |
|
| 124 | - } |
|
| 125 | - |
|
| 126 | - /** |
|
| 127 | - * @return bool |
|
| 128 | - */ |
|
| 129 | - public function hasSuggestions(): bool |
|
| 130 | - { |
|
| 131 | - return !empty($this->suggestions); |
|
| 132 | - } |
|
| 133 | - |
|
| 134 | - /** |
|
| 135 | - * @param string $dataType |
|
| 136 | - * @return $this |
|
| 137 | - */ |
|
| 138 | - public function setDataType($dataType): self |
|
| 139 | - { |
|
| 140 | - $this->dataType = $dataType; |
|
| 141 | - return $this; |
|
| 142 | - } |
|
| 143 | - |
|
| 144 | - /** |
|
| 145 | - * @return bool |
|
| 146 | - */ |
|
| 147 | - public function canModifyMatcher(): bool |
|
| 148 | - { |
|
| 149 | - return $this->canModifyMatcher; |
|
| 150 | - } |
|
| 151 | - |
|
| 152 | - /** |
|
| 153 | - * @param Matcher $matcher |
|
| 154 | - * @param $value |
|
| 155 | - * @return Matcher |
|
| 156 | - */ |
|
| 157 | - public function modifyMatcher(Matcher $matcher, $value): Matcher |
|
| 158 | - { |
|
| 159 | - return $matcher; |
|
| 160 | - } |
|
| 23 | + /** |
|
| 24 | + * @var string |
|
| 25 | + */ |
|
| 26 | + protected $name; |
|
| 27 | + |
|
| 28 | + /** |
|
| 29 | + * @var string |
|
| 30 | + */ |
|
| 31 | + protected $label; |
|
| 32 | + |
|
| 33 | + /** |
|
| 34 | + * @var array |
|
| 35 | + */ |
|
| 36 | + protected $suggestions = []; |
|
| 37 | + |
|
| 38 | + /** |
|
| 39 | + * @var string |
|
| 40 | + */ |
|
| 41 | + protected $dataType; |
|
| 42 | + |
|
| 43 | + /** |
|
| 44 | + * @var bool |
|
| 45 | + */ |
|
| 46 | + protected $canModifyMatcher = false; |
|
| 47 | + |
|
| 48 | + /** |
|
| 49 | + * Constructor of a Generic Facet in Vidi. |
|
| 50 | + * |
|
| 51 | + * @param string $name |
|
| 52 | + * @param string $label |
|
| 53 | + * @param array $suggestions |
|
| 54 | + */ |
|
| 55 | + public function __construct($name, $label = '', array $suggestions = []) |
|
| 56 | + { |
|
| 57 | + $this->name = $name; |
|
| 58 | + if (empty($label)) { |
|
| 59 | + $label = $this->name; |
|
| 60 | + } |
|
| 61 | + $this->label = $label; |
|
| 62 | + $this->suggestions = $suggestions; |
|
| 63 | + } |
|
| 64 | + |
|
| 65 | + /** |
|
| 66 | + * @return string |
|
| 67 | + */ |
|
| 68 | + public function getName(): string |
|
| 69 | + { |
|
| 70 | + return $this->name; |
|
| 71 | + } |
|
| 72 | + |
|
| 73 | + /** |
|
| 74 | + * @return string |
|
| 75 | + */ |
|
| 76 | + public function getLabel(): string |
|
| 77 | + { |
|
| 78 | + if ($this->label === $this->name) { |
|
| 79 | + $label = Tca::table($this->dataType)->field($this->getName())->getLabel(); |
|
| 80 | + } else { |
|
| 81 | + try { |
|
| 82 | + $label = LocalizationUtility::translate($this->label, ''); |
|
| 83 | + } catch (\InvalidArgumentException $e) { |
|
| 84 | + } |
|
| 85 | + if (empty($label)) { |
|
| 86 | + $label = $this->label; |
|
| 87 | + } |
|
| 88 | + } |
|
| 89 | + |
|
| 90 | + return $label; |
|
| 91 | + } |
|
| 92 | + |
|
| 93 | + /** |
|
| 94 | + * @return array |
|
| 95 | + */ |
|
| 96 | + public function getSuggestions(): array |
|
| 97 | + { |
|
| 98 | + $values = []; |
|
| 99 | + foreach ($this->suggestions as $key => $label) { |
|
| 100 | + $localizedLabel = $this->getLanguageService()->sL($label); |
|
| 101 | + if (!empty($localizedLabel)) { |
|
| 102 | + $label = $localizedLabel; |
|
| 103 | + } |
|
| 104 | + |
|
| 105 | + $values[] = [$key => $label]; |
|
| 106 | + } |
|
| 107 | + |
|
| 108 | + return $values; |
|
| 109 | + } |
|
| 110 | + |
|
| 111 | + /** |
|
| 112 | + * @return LanguageService |
|
| 113 | + */ |
|
| 114 | + protected function getLanguageService(): LanguageService |
|
| 115 | + { |
|
| 116 | + /** @var LanguageService $langService */ |
|
| 117 | + $langService = $GLOBALS['LANG']; |
|
| 118 | + if (!$langService) { |
|
| 119 | + $langService = GeneralUtility::makeInstance(LanguageService::class); |
|
| 120 | + $langService->init('en'); |
|
| 121 | + } |
|
| 122 | + |
|
| 123 | + return $langService; |
|
| 124 | + } |
|
| 125 | + |
|
| 126 | + /** |
|
| 127 | + * @return bool |
|
| 128 | + */ |
|
| 129 | + public function hasSuggestions(): bool |
|
| 130 | + { |
|
| 131 | + return !empty($this->suggestions); |
|
| 132 | + } |
|
| 133 | + |
|
| 134 | + /** |
|
| 135 | + * @param string $dataType |
|
| 136 | + * @return $this |
|
| 137 | + */ |
|
| 138 | + public function setDataType($dataType): self |
|
| 139 | + { |
|
| 140 | + $this->dataType = $dataType; |
|
| 141 | + return $this; |
|
| 142 | + } |
|
| 143 | + |
|
| 144 | + /** |
|
| 145 | + * @return bool |
|
| 146 | + */ |
|
| 147 | + public function canModifyMatcher(): bool |
|
| 148 | + { |
|
| 149 | + return $this->canModifyMatcher; |
|
| 150 | + } |
|
| 151 | + |
|
| 152 | + /** |
|
| 153 | + * @param Matcher $matcher |
|
| 154 | + * @param $value |
|
| 155 | + * @return Matcher |
|
| 156 | + */ |
|
| 157 | + public function modifyMatcher(Matcher $matcher, $value): Matcher |
|
| 158 | + { |
|
| 159 | + return $matcher; |
|
| 160 | + } |
|
| 161 | 161 | } |
@@ -20,162 +20,162 @@ |
||
| 20 | 20 | */ |
| 21 | 21 | class CompositeFacet implements FacetInterface |
| 22 | 22 | { |
| 23 | - /** |
|
| 24 | - * @var string |
|
| 25 | - */ |
|
| 26 | - protected $name; |
|
| 27 | - |
|
| 28 | - /** |
|
| 29 | - * @var string |
|
| 30 | - */ |
|
| 31 | - protected $label; |
|
| 32 | - |
|
| 33 | - /** |
|
| 34 | - * @var array |
|
| 35 | - */ |
|
| 36 | - protected $suggestions = [ |
|
| 37 | - '0' => 'LLL:EXT:vidi/Resources/Private/Language/locallang.xlf:active.0', |
|
| 38 | - ]; |
|
| 39 | - |
|
| 40 | - /** |
|
| 41 | - * @var array |
|
| 42 | - */ |
|
| 43 | - protected $configuration = []; |
|
| 44 | - |
|
| 45 | - /** |
|
| 46 | - * @var string |
|
| 47 | - */ |
|
| 48 | - protected $dataType; |
|
| 49 | - |
|
| 50 | - /** |
|
| 51 | - * @var bool |
|
| 52 | - */ |
|
| 53 | - protected $canModifyMatcher = true; |
|
| 54 | - |
|
| 55 | - /** |
|
| 56 | - * Constructor of a Generic Facet in Vidi. |
|
| 57 | - * |
|
| 58 | - * @param string $name |
|
| 59 | - * @param string $label |
|
| 60 | - * @param array $suggestions |
|
| 61 | - * @param array $configuration |
|
| 62 | - */ |
|
| 63 | - public function __construct($name, $label = '', array $suggestions = [], $configuration = []) |
|
| 64 | - { |
|
| 65 | - $this->name = $name; |
|
| 66 | - if (empty($label)) { |
|
| 67 | - $label = $this->name; |
|
| 68 | - } |
|
| 69 | - $this->label = $label; |
|
| 70 | - if ($suggestions) { |
|
| 71 | - $this->suggestions = $suggestions; |
|
| 72 | - } |
|
| 73 | - if ($configuration) { |
|
| 74 | - $this->configuration = $configuration; |
|
| 75 | - } |
|
| 76 | - } |
|
| 77 | - |
|
| 78 | - /** |
|
| 79 | - * @return string |
|
| 80 | - */ |
|
| 81 | - public function getName(): string |
|
| 82 | - { |
|
| 83 | - return $this->name; |
|
| 84 | - } |
|
| 85 | - |
|
| 86 | - /** |
|
| 87 | - * @return string |
|
| 88 | - */ |
|
| 89 | - public function getLabel(): string |
|
| 90 | - { |
|
| 91 | - if ($this->label === $this->name) { |
|
| 92 | - $label = Tca::table($this->dataType)->field($this->getName())->getLabel(); |
|
| 93 | - } else { |
|
| 94 | - try { |
|
| 95 | - $label = LocalizationUtility::translate($this->label, ''); |
|
| 96 | - } catch (\InvalidArgumentException $e) { |
|
| 97 | - } |
|
| 98 | - if (empty($label)) { |
|
| 99 | - $label = $this->label; |
|
| 100 | - } |
|
| 101 | - } |
|
| 102 | - |
|
| 103 | - return $label; |
|
| 104 | - } |
|
| 105 | - |
|
| 106 | - /** |
|
| 107 | - * @return array |
|
| 108 | - */ |
|
| 109 | - public function getSuggestions(): array |
|
| 110 | - { |
|
| 111 | - $values = []; |
|
| 112 | - foreach ($this->suggestions as $key => $label) { |
|
| 113 | - $localizedLabel = $this->getLanguageService()->sL($label); |
|
| 114 | - if (!empty($localizedLabel)) { |
|
| 115 | - $label = $localizedLabel; |
|
| 116 | - } |
|
| 117 | - |
|
| 118 | - $values[] = [$key => $label]; |
|
| 119 | - } |
|
| 120 | - |
|
| 121 | - return $values; |
|
| 122 | - } |
|
| 123 | - |
|
| 124 | - /** |
|
| 125 | - * @return LanguageService |
|
| 126 | - */ |
|
| 127 | - protected function getLanguageService(): LanguageService |
|
| 128 | - { |
|
| 129 | - /** @var LanguageService $langService */ |
|
| 130 | - $langService = $GLOBALS['LANG']; |
|
| 131 | - if (!$langService) { |
|
| 132 | - $langService = GeneralUtility::makeInstance(LanguageService::class); |
|
| 133 | - $langService->init('en'); |
|
| 134 | - } |
|
| 135 | - |
|
| 136 | - return $langService; |
|
| 137 | - } |
|
| 138 | - |
|
| 139 | - /** |
|
| 140 | - * @return bool |
|
| 141 | - */ |
|
| 142 | - public function hasSuggestions(): bool |
|
| 143 | - { |
|
| 144 | - return !empty($this->suggestions); |
|
| 145 | - } |
|
| 146 | - |
|
| 147 | - /** |
|
| 148 | - * @param string $dataType |
|
| 149 | - * @return $this |
|
| 150 | - */ |
|
| 151 | - public function setDataType($dataType): self |
|
| 152 | - { |
|
| 153 | - $this->dataType = $dataType; |
|
| 154 | - return $this; |
|
| 155 | - } |
|
| 156 | - |
|
| 157 | - /** |
|
| 158 | - * @return bool |
|
| 159 | - */ |
|
| 160 | - public function canModifyMatcher(): bool |
|
| 161 | - { |
|
| 162 | - return $this->canModifyMatcher; |
|
| 163 | - } |
|
| 164 | - |
|
| 165 | - /** |
|
| 166 | - * @param Matcher $matcher |
|
| 167 | - * @param $value |
|
| 168 | - * @return Matcher |
|
| 169 | - */ |
|
| 170 | - public function modifyMatcher(Matcher $matcher, $value): Matcher |
|
| 171 | - { |
|
| 172 | - foreach ($this->configuration as $fieldNameAndPath => $operand) { |
|
| 173 | - if ($operand === '*') { |
|
| 174 | - $matcher->notEquals($fieldNameAndPath, ''); |
|
| 175 | - } else { |
|
| 176 | - $matcher->equals($fieldNameAndPath, $operand); |
|
| 177 | - } |
|
| 178 | - } |
|
| 179 | - return $matcher; |
|
| 180 | - } |
|
| 23 | + /** |
|
| 24 | + * @var string |
|
| 25 | + */ |
|
| 26 | + protected $name; |
|
| 27 | + |
|
| 28 | + /** |
|
| 29 | + * @var string |
|
| 30 | + */ |
|
| 31 | + protected $label; |
|
| 32 | + |
|
| 33 | + /** |
|
| 34 | + * @var array |
|
| 35 | + */ |
|
| 36 | + protected $suggestions = [ |
|
| 37 | + '0' => 'LLL:EXT:vidi/Resources/Private/Language/locallang.xlf:active.0', |
|
| 38 | + ]; |
|
| 39 | + |
|
| 40 | + /** |
|
| 41 | + * @var array |
|
| 42 | + */ |
|
| 43 | + protected $configuration = []; |
|
| 44 | + |
|
| 45 | + /** |
|
| 46 | + * @var string |
|
| 47 | + */ |
|
| 48 | + protected $dataType; |
|
| 49 | + |
|
| 50 | + /** |
|
| 51 | + * @var bool |
|
| 52 | + */ |
|
| 53 | + protected $canModifyMatcher = true; |
|
| 54 | + |
|
| 55 | + /** |
|
| 56 | + * Constructor of a Generic Facet in Vidi. |
|
| 57 | + * |
|
| 58 | + * @param string $name |
|
| 59 | + * @param string $label |
|
| 60 | + * @param array $suggestions |
|
| 61 | + * @param array $configuration |
|
| 62 | + */ |
|
| 63 | + public function __construct($name, $label = '', array $suggestions = [], $configuration = []) |
|
| 64 | + { |
|
| 65 | + $this->name = $name; |
|
| 66 | + if (empty($label)) { |
|
| 67 | + $label = $this->name; |
|
| 68 | + } |
|
| 69 | + $this->label = $label; |
|
| 70 | + if ($suggestions) { |
|
| 71 | + $this->suggestions = $suggestions; |
|
| 72 | + } |
|
| 73 | + if ($configuration) { |
|
| 74 | + $this->configuration = $configuration; |
|
| 75 | + } |
|
| 76 | + } |
|
| 77 | + |
|
| 78 | + /** |
|
| 79 | + * @return string |
|
| 80 | + */ |
|
| 81 | + public function getName(): string |
|
| 82 | + { |
|
| 83 | + return $this->name; |
|
| 84 | + } |
|
| 85 | + |
|
| 86 | + /** |
|
| 87 | + * @return string |
|
| 88 | + */ |
|
| 89 | + public function getLabel(): string |
|
| 90 | + { |
|
| 91 | + if ($this->label === $this->name) { |
|
| 92 | + $label = Tca::table($this->dataType)->field($this->getName())->getLabel(); |
|
| 93 | + } else { |
|
| 94 | + try { |
|
| 95 | + $label = LocalizationUtility::translate($this->label, ''); |
|
| 96 | + } catch (\InvalidArgumentException $e) { |
|
| 97 | + } |
|
| 98 | + if (empty($label)) { |
|
| 99 | + $label = $this->label; |
|
| 100 | + } |
|
| 101 | + } |
|
| 102 | + |
|
| 103 | + return $label; |
|
| 104 | + } |
|
| 105 | + |
|
| 106 | + /** |
|
| 107 | + * @return array |
|
| 108 | + */ |
|
| 109 | + public function getSuggestions(): array |
|
| 110 | + { |
|
| 111 | + $values = []; |
|
| 112 | + foreach ($this->suggestions as $key => $label) { |
|
| 113 | + $localizedLabel = $this->getLanguageService()->sL($label); |
|
| 114 | + if (!empty($localizedLabel)) { |
|
| 115 | + $label = $localizedLabel; |
|
| 116 | + } |
|
| 117 | + |
|
| 118 | + $values[] = [$key => $label]; |
|
| 119 | + } |
|
| 120 | + |
|
| 121 | + return $values; |
|
| 122 | + } |
|
| 123 | + |
|
| 124 | + /** |
|
| 125 | + * @return LanguageService |
|
| 126 | + */ |
|
| 127 | + protected function getLanguageService(): LanguageService |
|
| 128 | + { |
|
| 129 | + /** @var LanguageService $langService */ |
|
| 130 | + $langService = $GLOBALS['LANG']; |
|
| 131 | + if (!$langService) { |
|
| 132 | + $langService = GeneralUtility::makeInstance(LanguageService::class); |
|
| 133 | + $langService->init('en'); |
|
| 134 | + } |
|
| 135 | + |
|
| 136 | + return $langService; |
|
| 137 | + } |
|
| 138 | + |
|
| 139 | + /** |
|
| 140 | + * @return bool |
|
| 141 | + */ |
|
| 142 | + public function hasSuggestions(): bool |
|
| 143 | + { |
|
| 144 | + return !empty($this->suggestions); |
|
| 145 | + } |
|
| 146 | + |
|
| 147 | + /** |
|
| 148 | + * @param string $dataType |
|
| 149 | + * @return $this |
|
| 150 | + */ |
|
| 151 | + public function setDataType($dataType): self |
|
| 152 | + { |
|
| 153 | + $this->dataType = $dataType; |
|
| 154 | + return $this; |
|
| 155 | + } |
|
| 156 | + |
|
| 157 | + /** |
|
| 158 | + * @return bool |
|
| 159 | + */ |
|
| 160 | + public function canModifyMatcher(): bool |
|
| 161 | + { |
|
| 162 | + return $this->canModifyMatcher; |
|
| 163 | + } |
|
| 164 | + |
|
| 165 | + /** |
|
| 166 | + * @param Matcher $matcher |
|
| 167 | + * @param $value |
|
| 168 | + * @return Matcher |
|
| 169 | + */ |
|
| 170 | + public function modifyMatcher(Matcher $matcher, $value): Matcher |
|
| 171 | + { |
|
| 172 | + foreach ($this->configuration as $fieldNameAndPath => $operand) { |
|
| 173 | + if ($operand === '*') { |
|
| 174 | + $matcher->notEquals($fieldNameAndPath, ''); |
|
| 175 | + } else { |
|
| 176 | + $matcher->equals($fieldNameAndPath, $operand); |
|
| 177 | + } |
|
| 178 | + } |
|
| 179 | + return $matcher; |
|
| 180 | + } |
|
| 181 | 181 | } |
@@ -16,51 +16,51 @@ |
||
| 16 | 16 | */ |
| 17 | 17 | interface FacetInterface |
| 18 | 18 | { |
| 19 | - /** |
|
| 20 | - * Return the "key" of the facet. |
|
| 21 | - * |
|
| 22 | - * @return string |
|
| 23 | - */ |
|
| 24 | - public function getName(); |
|
| 19 | + /** |
|
| 20 | + * Return the "key" of the facet. |
|
| 21 | + * |
|
| 22 | + * @return string |
|
| 23 | + */ |
|
| 24 | + public function getName(); |
|
| 25 | 25 | |
| 26 | - /** |
|
| 27 | - * Return the "label" of the facet. |
|
| 28 | - * |
|
| 29 | - * @return string |
|
| 30 | - */ |
|
| 31 | - public function getLabel(); |
|
| 26 | + /** |
|
| 27 | + * Return the "label" of the facet. |
|
| 28 | + * |
|
| 29 | + * @return string |
|
| 30 | + */ |
|
| 31 | + public function getLabel(); |
|
| 32 | 32 | |
| 33 | - /** |
|
| 34 | - * Return possible "suggestions" of the facet. |
|
| 35 | - * |
|
| 36 | - * @return array |
|
| 37 | - */ |
|
| 38 | - public function getSuggestions(); |
|
| 33 | + /** |
|
| 34 | + * Return possible "suggestions" of the facet. |
|
| 35 | + * |
|
| 36 | + * @return array |
|
| 37 | + */ |
|
| 38 | + public function getSuggestions(); |
|
| 39 | 39 | |
| 40 | - /** |
|
| 41 | - * Tell whether the Facet has suggestion or not. |
|
| 42 | - * |
|
| 43 | - * @return bool |
|
| 44 | - */ |
|
| 45 | - public function hasSuggestions(); |
|
| 40 | + /** |
|
| 41 | + * Tell whether the Facet has suggestion or not. |
|
| 42 | + * |
|
| 43 | + * @return bool |
|
| 44 | + */ |
|
| 45 | + public function hasSuggestions(); |
|
| 46 | 46 | |
| 47 | - /** |
|
| 48 | - * Set the data type. |
|
| 49 | - * |
|
| 50 | - * @param string $dataType |
|
| 51 | - * @return $this |
|
| 52 | - */ |
|
| 53 | - public function setDataType($dataType); |
|
| 47 | + /** |
|
| 48 | + * Set the data type. |
|
| 49 | + * |
|
| 50 | + * @param string $dataType |
|
| 51 | + * @return $this |
|
| 52 | + */ |
|
| 53 | + public function setDataType($dataType); |
|
| 54 | 54 | |
| 55 | - /** |
|
| 56 | - * @return bool |
|
| 57 | - */ |
|
| 58 | - public function canModifyMatcher(); |
|
| 55 | + /** |
|
| 56 | + * @return bool |
|
| 57 | + */ |
|
| 58 | + public function canModifyMatcher(); |
|
| 59 | 59 | |
| 60 | - /** |
|
| 61 | - * @param Matcher $matcher |
|
| 62 | - * @param $value |
|
| 63 | - * @return Matcher |
|
| 64 | - */ |
|
| 65 | - public function modifyMatcher(Matcher $matcher, $value); |
|
| 60 | + /** |
|
| 61 | + * @param Matcher $matcher |
|
| 62 | + * @param $value |
|
| 63 | + * @return Matcher |
|
| 64 | + */ |
|
| 65 | + public function modifyMatcher(Matcher $matcher, $value); |
|
| 66 | 66 | } |
@@ -21,103 +21,103 @@ |
||
| 21 | 21 | */ |
| 22 | 22 | class FacetSuggestionService |
| 23 | 23 | { |
| 24 | - /** |
|
| 25 | - * Retrieve possible suggestions for a field name |
|
| 26 | - * |
|
| 27 | - * @param string $fieldNameAndPath |
|
| 28 | - * @return array |
|
| 29 | - */ |
|
| 30 | - public function getSuggestions($fieldNameAndPath): array |
|
| 31 | - { |
|
| 32 | - $values = []; |
|
| 33 | - |
|
| 34 | - $dataType = $this->getFieldPathResolver()->getDataType($fieldNameAndPath); |
|
| 35 | - $fieldName = $this->getFieldPathResolver()->stripFieldPath($fieldNameAndPath); |
|
| 36 | - |
|
| 37 | - if (Tca::grid()->facet($fieldNameAndPath)->hasSuggestions()) { |
|
| 38 | - $values = Tca::grid()->facet($fieldNameAndPath)->getSuggestions(); |
|
| 39 | - } elseif (Tca::table($dataType)->hasField($fieldName)) { |
|
| 40 | - if (Tca::table($dataType)->field($fieldName)->hasRelation()) { |
|
| 41 | - // Fetch the adequate repository |
|
| 42 | - $foreignTable = Tca::table($dataType)->field($fieldName)->getForeignTable(); |
|
| 43 | - $contentRepository = ContentRepositoryFactory::getInstance($foreignTable); |
|
| 44 | - $table = Tca::table($foreignTable); |
|
| 45 | - |
|
| 46 | - // Initialize the matcher object. |
|
| 47 | - $matcher = MatcherObjectFactory::getInstance()->getMatcher([], $foreignTable); |
|
| 48 | - |
|
| 49 | - $numberOfValues = $contentRepository->countBy($matcher); |
|
| 50 | - if ($numberOfValues <= $this->getLimit()) { |
|
| 51 | - $contents = $contentRepository->findBy($matcher); |
|
| 52 | - |
|
| 53 | - foreach ($contents as $content) { |
|
| 54 | - $values[] = array($content->getUid() => $content[$table->getLabelField()]); |
|
| 55 | - } |
|
| 56 | - } |
|
| 57 | - } elseif (!Tca::table($dataType)->field($fieldName)->isTextArea()) { // We don't want suggestion if field is text area. |
|
| 58 | - // Fetch the adequate repository |
|
| 59 | - /** @var ContentRepository $contentRepository */ |
|
| 60 | - $contentRepository = ContentRepositoryFactory::getInstance($dataType); |
|
| 61 | - |
|
| 62 | - // Initialize some objects related to the query |
|
| 63 | - $matcher = MatcherObjectFactory::getInstance()->getMatcher([], $dataType); |
|
| 64 | - |
|
| 65 | - // Count the number of objects. |
|
| 66 | - $numberOfValues = $contentRepository->countDistinctValues($fieldName, $matcher); |
|
| 67 | - |
|
| 68 | - // Only returns suggestion if there are not too many for the browser. |
|
| 69 | - if ($numberOfValues <= $this->getLimit()) { |
|
| 70 | - // Query the repository. |
|
| 71 | - $contents = $contentRepository->findDistinctValues($fieldName, $matcher); |
|
| 72 | - |
|
| 73 | - foreach ($contents as $content) { |
|
| 74 | - $value = $content[$fieldName]; |
|
| 75 | - $label = $content[$fieldName]; |
|
| 76 | - if (Tca::table($dataType)->field($fieldName)->isSelect()) { |
|
| 77 | - $label = Tca::table($dataType)->field($fieldName)->getLabelForItem($value); |
|
| 78 | - } |
|
| 79 | - |
|
| 80 | - $values[] = $label; |
|
| 81 | - } |
|
| 82 | - } |
|
| 83 | - } |
|
| 84 | - } |
|
| 85 | - return $values; |
|
| 86 | - } |
|
| 87 | - |
|
| 88 | - /** |
|
| 89 | - * Return from settings the suggestion limit. |
|
| 90 | - * |
|
| 91 | - * @return int |
|
| 92 | - */ |
|
| 93 | - protected function getLimit(): int |
|
| 94 | - { |
|
| 95 | - $settings = $this->getSettings(); |
|
| 96 | - $suggestionLimit = (int)$settings['suggestionLimit']; |
|
| 97 | - if ($suggestionLimit <= 0) { |
|
| 98 | - $suggestionLimit = 1000; |
|
| 99 | - } |
|
| 100 | - return $suggestionLimit; |
|
| 101 | - } |
|
| 102 | - |
|
| 103 | - /** |
|
| 104 | - * @return FieldPathResolver|object |
|
| 105 | - */ |
|
| 106 | - protected function getFieldPathResolver() |
|
| 107 | - { |
|
| 108 | - return GeneralUtility::makeInstance(FieldPathResolver::class); |
|
| 109 | - } |
|
| 110 | - |
|
| 111 | - /** |
|
| 112 | - * Returns the module settings. |
|
| 113 | - * |
|
| 114 | - * @return array |
|
| 115 | - */ |
|
| 116 | - protected function getSettings() |
|
| 117 | - { |
|
| 118 | - /** @var BackendConfigurationManager $backendConfigurationManager */ |
|
| 119 | - $backendConfigurationManager = GeneralUtility::makeInstance(BackendConfigurationManager::class); |
|
| 120 | - $configuration = $backendConfigurationManager->getTypoScriptSetup(); |
|
| 121 | - return $configuration['module.']['tx_vidi.']['settings.']; |
|
| 122 | - } |
|
| 24 | + /** |
|
| 25 | + * Retrieve possible suggestions for a field name |
|
| 26 | + * |
|
| 27 | + * @param string $fieldNameAndPath |
|
| 28 | + * @return array |
|
| 29 | + */ |
|
| 30 | + public function getSuggestions($fieldNameAndPath): array |
|
| 31 | + { |
|
| 32 | + $values = []; |
|
| 33 | + |
|
| 34 | + $dataType = $this->getFieldPathResolver()->getDataType($fieldNameAndPath); |
|
| 35 | + $fieldName = $this->getFieldPathResolver()->stripFieldPath($fieldNameAndPath); |
|
| 36 | + |
|
| 37 | + if (Tca::grid()->facet($fieldNameAndPath)->hasSuggestions()) { |
|
| 38 | + $values = Tca::grid()->facet($fieldNameAndPath)->getSuggestions(); |
|
| 39 | + } elseif (Tca::table($dataType)->hasField($fieldName)) { |
|
| 40 | + if (Tca::table($dataType)->field($fieldName)->hasRelation()) { |
|
| 41 | + // Fetch the adequate repository |
|
| 42 | + $foreignTable = Tca::table($dataType)->field($fieldName)->getForeignTable(); |
|
| 43 | + $contentRepository = ContentRepositoryFactory::getInstance($foreignTable); |
|
| 44 | + $table = Tca::table($foreignTable); |
|
| 45 | + |
|
| 46 | + // Initialize the matcher object. |
|
| 47 | + $matcher = MatcherObjectFactory::getInstance()->getMatcher([], $foreignTable); |
|
| 48 | + |
|
| 49 | + $numberOfValues = $contentRepository->countBy($matcher); |
|
| 50 | + if ($numberOfValues <= $this->getLimit()) { |
|
| 51 | + $contents = $contentRepository->findBy($matcher); |
|
| 52 | + |
|
| 53 | + foreach ($contents as $content) { |
|
| 54 | + $values[] = array($content->getUid() => $content[$table->getLabelField()]); |
|
| 55 | + } |
|
| 56 | + } |
|
| 57 | + } elseif (!Tca::table($dataType)->field($fieldName)->isTextArea()) { // We don't want suggestion if field is text area. |
|
| 58 | + // Fetch the adequate repository |
|
| 59 | + /** @var ContentRepository $contentRepository */ |
|
| 60 | + $contentRepository = ContentRepositoryFactory::getInstance($dataType); |
|
| 61 | + |
|
| 62 | + // Initialize some objects related to the query |
|
| 63 | + $matcher = MatcherObjectFactory::getInstance()->getMatcher([], $dataType); |
|
| 64 | + |
|
| 65 | + // Count the number of objects. |
|
| 66 | + $numberOfValues = $contentRepository->countDistinctValues($fieldName, $matcher); |
|
| 67 | + |
|
| 68 | + // Only returns suggestion if there are not too many for the browser. |
|
| 69 | + if ($numberOfValues <= $this->getLimit()) { |
|
| 70 | + // Query the repository. |
|
| 71 | + $contents = $contentRepository->findDistinctValues($fieldName, $matcher); |
|
| 72 | + |
|
| 73 | + foreach ($contents as $content) { |
|
| 74 | + $value = $content[$fieldName]; |
|
| 75 | + $label = $content[$fieldName]; |
|
| 76 | + if (Tca::table($dataType)->field($fieldName)->isSelect()) { |
|
| 77 | + $label = Tca::table($dataType)->field($fieldName)->getLabelForItem($value); |
|
| 78 | + } |
|
| 79 | + |
|
| 80 | + $values[] = $label; |
|
| 81 | + } |
|
| 82 | + } |
|
| 83 | + } |
|
| 84 | + } |
|
| 85 | + return $values; |
|
| 86 | + } |
|
| 87 | + |
|
| 88 | + /** |
|
| 89 | + * Return from settings the suggestion limit. |
|
| 90 | + * |
|
| 91 | + * @return int |
|
| 92 | + */ |
|
| 93 | + protected function getLimit(): int |
|
| 94 | + { |
|
| 95 | + $settings = $this->getSettings(); |
|
| 96 | + $suggestionLimit = (int)$settings['suggestionLimit']; |
|
| 97 | + if ($suggestionLimit <= 0) { |
|
| 98 | + $suggestionLimit = 1000; |
|
| 99 | + } |
|
| 100 | + return $suggestionLimit; |
|
| 101 | + } |
|
| 102 | + |
|
| 103 | + /** |
|
| 104 | + * @return FieldPathResolver|object |
|
| 105 | + */ |
|
| 106 | + protected function getFieldPathResolver() |
|
| 107 | + { |
|
| 108 | + return GeneralUtility::makeInstance(FieldPathResolver::class); |
|
| 109 | + } |
|
| 110 | + |
|
| 111 | + /** |
|
| 112 | + * Returns the module settings. |
|
| 113 | + * |
|
| 114 | + * @return array |
|
| 115 | + */ |
|
| 116 | + protected function getSettings() |
|
| 117 | + { |
|
| 118 | + /** @var BackendConfigurationManager $backendConfigurationManager */ |
|
| 119 | + $backendConfigurationManager = GeneralUtility::makeInstance(BackendConfigurationManager::class); |
|
| 120 | + $configuration = $backendConfigurationManager->getTypoScriptSetup(); |
|
| 121 | + return $configuration['module.']['tx_vidi.']['settings.']; |
|
| 122 | + } |
|
| 123 | 123 | } |
@@ -19,190 +19,190 @@ |
||
| 19 | 19 | */ |
| 20 | 20 | abstract class ColumnRendererAbstract implements ColumnRendererInterface |
| 21 | 21 | { |
| 22 | - /** |
|
| 23 | - * The content object. |
|
| 24 | - * |
|
| 25 | - * @var Content |
|
| 26 | - */ |
|
| 27 | - protected $object; |
|
| 28 | - |
|
| 29 | - /** |
|
| 30 | - * @var string |
|
| 31 | - */ |
|
| 32 | - protected $fieldName; |
|
| 33 | - |
|
| 34 | - /** |
|
| 35 | - * @var int |
|
| 36 | - */ |
|
| 37 | - protected $rowIndex; |
|
| 38 | - |
|
| 39 | - /** |
|
| 40 | - * @var array |
|
| 41 | - */ |
|
| 42 | - protected $fieldConfiguration = []; |
|
| 43 | - |
|
| 44 | - /** |
|
| 45 | - * @var array |
|
| 46 | - */ |
|
| 47 | - protected $gridRendererConfiguration = []; |
|
| 48 | - |
|
| 49 | - /** |
|
| 50 | - * @var array |
|
| 51 | - */ |
|
| 52 | - protected $configuration = []; |
|
| 53 | - |
|
| 54 | - /** |
|
| 55 | - * Constructor of a Generic component in Vidi. |
|
| 56 | - * |
|
| 57 | - * @param array $configuration |
|
| 58 | - * @param array $legacyParameterConfiguration |
|
| 59 | - */ |
|
| 60 | - public function __construct($configuration = [], $legacyParameterConfiguration = array()) |
|
| 61 | - { |
|
| 62 | - if (is_string($configuration)) { |
|
| 63 | - $configuration = $legacyParameterConfiguration; |
|
| 64 | - trigger_error('ColumnRendererAbstract: first parameter must now be an array. Please edit me in ' . get_class($this), E_USER_DEPRECATED); |
|
| 65 | - } |
|
| 66 | - $this->configuration = $configuration; |
|
| 67 | - } |
|
| 68 | - |
|
| 69 | - /** |
|
| 70 | - * @return array |
|
| 71 | - */ |
|
| 72 | - public function getConfiguration() |
|
| 73 | - { |
|
| 74 | - return $this->configuration; |
|
| 75 | - } |
|
| 76 | - |
|
| 77 | - /** |
|
| 78 | - * @return Content |
|
| 79 | - */ |
|
| 80 | - public function getObject() |
|
| 81 | - { |
|
| 82 | - return $this->object; |
|
| 83 | - } |
|
| 84 | - |
|
| 85 | - /** |
|
| 86 | - * @param Content $object |
|
| 87 | - * @return $this |
|
| 88 | - */ |
|
| 89 | - public function setObject($object) |
|
| 90 | - { |
|
| 91 | - $this->object = $object; |
|
| 92 | - return $this; |
|
| 93 | - } |
|
| 94 | - |
|
| 95 | - /** |
|
| 96 | - * @return string |
|
| 97 | - */ |
|
| 98 | - public function getFieldName() |
|
| 99 | - { |
|
| 100 | - return $this->fieldName; |
|
| 101 | - } |
|
| 102 | - |
|
| 103 | - /** |
|
| 104 | - * @param string $fieldName |
|
| 105 | - * @return $this |
|
| 106 | - */ |
|
| 107 | - public function setFieldName($fieldName) |
|
| 108 | - { |
|
| 109 | - $this->fieldName = $fieldName; |
|
| 110 | - return $this; |
|
| 111 | - } |
|
| 112 | - |
|
| 113 | - /** |
|
| 114 | - * @return int |
|
| 115 | - */ |
|
| 116 | - public function getRowIndex() |
|
| 117 | - { |
|
| 118 | - return $this->rowIndex; |
|
| 119 | - } |
|
| 120 | - |
|
| 121 | - /** |
|
| 122 | - * @param int $rowIndex |
|
| 123 | - * @return $this |
|
| 124 | - */ |
|
| 125 | - public function setRowIndex($rowIndex) |
|
| 126 | - { |
|
| 127 | - $this->rowIndex = $rowIndex; |
|
| 128 | - return $this; |
|
| 129 | - } |
|
| 130 | - |
|
| 131 | - /** |
|
| 132 | - * @return array |
|
| 133 | - */ |
|
| 134 | - public function getFieldConfiguration() |
|
| 135 | - { |
|
| 136 | - return $this->fieldConfiguration; |
|
| 137 | - } |
|
| 138 | - |
|
| 139 | - /** |
|
| 140 | - * @param array $fieldConfiguration |
|
| 141 | - * @return $this |
|
| 142 | - */ |
|
| 143 | - public function setFieldConfiguration($fieldConfiguration) |
|
| 144 | - { |
|
| 145 | - $this->fieldConfiguration = $fieldConfiguration; |
|
| 146 | - return $this; |
|
| 147 | - } |
|
| 148 | - |
|
| 149 | - /** |
|
| 150 | - * @return array |
|
| 151 | - */ |
|
| 152 | - public function getGridRendererConfiguration() |
|
| 153 | - { |
|
| 154 | - return $this->gridRendererConfiguration; |
|
| 155 | - } |
|
| 156 | - |
|
| 157 | - /** |
|
| 158 | - * @param array $gridRendererConfiguration |
|
| 159 | - * @return $this |
|
| 160 | - */ |
|
| 161 | - public function setGridRendererConfiguration($gridRendererConfiguration) |
|
| 162 | - { |
|
| 163 | - $this->gridRendererConfiguration = $gridRendererConfiguration; |
|
| 164 | - return $this; |
|
| 165 | - } |
|
| 166 | - |
|
| 167 | - /** |
|
| 168 | - * Escapes special characters with their escaped counterparts as needed using PHPs htmlentities() function. |
|
| 169 | - * |
|
| 170 | - * @param string $value string to format |
|
| 171 | - * @param bool $keepQuotes if TRUE, single and double quotes won't be replaced (sets ENT_NOQUOTES flag) |
|
| 172 | - * @param string $encoding |
|
| 173 | - * @return string |
|
| 174 | - * @see http://www.php.net/manual/function.htmlentities.php |
|
| 175 | - * @api |
|
| 176 | - */ |
|
| 177 | - protected function secure($value, $keepQuotes = false, $encoding = 'UTF-8') |
|
| 178 | - { |
|
| 179 | - $flags = $keepQuotes ? ENT_NOQUOTES : ENT_COMPAT; |
|
| 180 | - return htmlspecialchars($value, $flags, $encoding); |
|
| 181 | - } |
|
| 182 | - |
|
| 183 | - /** |
|
| 184 | - * Get the Vidi Module Loader. |
|
| 185 | - * |
|
| 186 | - * @return object|ModuleLoader |
|
| 187 | - */ |
|
| 188 | - protected function getModuleLoader() |
|
| 189 | - { |
|
| 190 | - return GeneralUtility::makeInstance(ModuleLoader::class); |
|
| 191 | - } |
|
| 192 | - |
|
| 193 | - /** |
|
| 194 | - * @return object|IconFactory |
|
| 195 | - */ |
|
| 196 | - protected function getIconFactory() |
|
| 197 | - { |
|
| 198 | - return GeneralUtility::makeInstance(IconFactory::class); |
|
| 199 | - } |
|
| 200 | - |
|
| 201 | - /** |
|
| 202 | - * @return object|LanguageService |
|
| 203 | - */ |
|
| 204 | - protected function getLanguageService() |
|
| 205 | - { |
|
| 206 | - return GeneralUtility::makeInstance(LanguageService::class); |
|
| 207 | - } |
|
| 22 | + /** |
|
| 23 | + * The content object. |
|
| 24 | + * |
|
| 25 | + * @var Content |
|
| 26 | + */ |
|
| 27 | + protected $object; |
|
| 28 | + |
|
| 29 | + /** |
|
| 30 | + * @var string |
|
| 31 | + */ |
|
| 32 | + protected $fieldName; |
|
| 33 | + |
|
| 34 | + /** |
|
| 35 | + * @var int |
|
| 36 | + */ |
|
| 37 | + protected $rowIndex; |
|
| 38 | + |
|
| 39 | + /** |
|
| 40 | + * @var array |
|
| 41 | + */ |
|
| 42 | + protected $fieldConfiguration = []; |
|
| 43 | + |
|
| 44 | + /** |
|
| 45 | + * @var array |
|
| 46 | + */ |
|
| 47 | + protected $gridRendererConfiguration = []; |
|
| 48 | + |
|
| 49 | + /** |
|
| 50 | + * @var array |
|
| 51 | + */ |
|
| 52 | + protected $configuration = []; |
|
| 53 | + |
|
| 54 | + /** |
|
| 55 | + * Constructor of a Generic component in Vidi. |
|
| 56 | + * |
|
| 57 | + * @param array $configuration |
|
| 58 | + * @param array $legacyParameterConfiguration |
|
| 59 | + */ |
|
| 60 | + public function __construct($configuration = [], $legacyParameterConfiguration = array()) |
|
| 61 | + { |
|
| 62 | + if (is_string($configuration)) { |
|
| 63 | + $configuration = $legacyParameterConfiguration; |
|
| 64 | + trigger_error('ColumnRendererAbstract: first parameter must now be an array. Please edit me in ' . get_class($this), E_USER_DEPRECATED); |
|
| 65 | + } |
|
| 66 | + $this->configuration = $configuration; |
|
| 67 | + } |
|
| 68 | + |
|
| 69 | + /** |
|
| 70 | + * @return array |
|
| 71 | + */ |
|
| 72 | + public function getConfiguration() |
|
| 73 | + { |
|
| 74 | + return $this->configuration; |
|
| 75 | + } |
|
| 76 | + |
|
| 77 | + /** |
|
| 78 | + * @return Content |
|
| 79 | + */ |
|
| 80 | + public function getObject() |
|
| 81 | + { |
|
| 82 | + return $this->object; |
|
| 83 | + } |
|
| 84 | + |
|
| 85 | + /** |
|
| 86 | + * @param Content $object |
|
| 87 | + * @return $this |
|
| 88 | + */ |
|
| 89 | + public function setObject($object) |
|
| 90 | + { |
|
| 91 | + $this->object = $object; |
|
| 92 | + return $this; |
|
| 93 | + } |
|
| 94 | + |
|
| 95 | + /** |
|
| 96 | + * @return string |
|
| 97 | + */ |
|
| 98 | + public function getFieldName() |
|
| 99 | + { |
|
| 100 | + return $this->fieldName; |
|
| 101 | + } |
|
| 102 | + |
|
| 103 | + /** |
|
| 104 | + * @param string $fieldName |
|
| 105 | + * @return $this |
|
| 106 | + */ |
|
| 107 | + public function setFieldName($fieldName) |
|
| 108 | + { |
|
| 109 | + $this->fieldName = $fieldName; |
|
| 110 | + return $this; |
|
| 111 | + } |
|
| 112 | + |
|
| 113 | + /** |
|
| 114 | + * @return int |
|
| 115 | + */ |
|
| 116 | + public function getRowIndex() |
|
| 117 | + { |
|
| 118 | + return $this->rowIndex; |
|
| 119 | + } |
|
| 120 | + |
|
| 121 | + /** |
|
| 122 | + * @param int $rowIndex |
|
| 123 | + * @return $this |
|
| 124 | + */ |
|
| 125 | + public function setRowIndex($rowIndex) |
|
| 126 | + { |
|
| 127 | + $this->rowIndex = $rowIndex; |
|
| 128 | + return $this; |
|
| 129 | + } |
|
| 130 | + |
|
| 131 | + /** |
|
| 132 | + * @return array |
|
| 133 | + */ |
|
| 134 | + public function getFieldConfiguration() |
|
| 135 | + { |
|
| 136 | + return $this->fieldConfiguration; |
|
| 137 | + } |
|
| 138 | + |
|
| 139 | + /** |
|
| 140 | + * @param array $fieldConfiguration |
|
| 141 | + * @return $this |
|
| 142 | + */ |
|
| 143 | + public function setFieldConfiguration($fieldConfiguration) |
|
| 144 | + { |
|
| 145 | + $this->fieldConfiguration = $fieldConfiguration; |
|
| 146 | + return $this; |
|
| 147 | + } |
|
| 148 | + |
|
| 149 | + /** |
|
| 150 | + * @return array |
|
| 151 | + */ |
|
| 152 | + public function getGridRendererConfiguration() |
|
| 153 | + { |
|
| 154 | + return $this->gridRendererConfiguration; |
|
| 155 | + } |
|
| 156 | + |
|
| 157 | + /** |
|
| 158 | + * @param array $gridRendererConfiguration |
|
| 159 | + * @return $this |
|
| 160 | + */ |
|
| 161 | + public function setGridRendererConfiguration($gridRendererConfiguration) |
|
| 162 | + { |
|
| 163 | + $this->gridRendererConfiguration = $gridRendererConfiguration; |
|
| 164 | + return $this; |
|
| 165 | + } |
|
| 166 | + |
|
| 167 | + /** |
|
| 168 | + * Escapes special characters with their escaped counterparts as needed using PHPs htmlentities() function. |
|
| 169 | + * |
|
| 170 | + * @param string $value string to format |
|
| 171 | + * @param bool $keepQuotes if TRUE, single and double quotes won't be replaced (sets ENT_NOQUOTES flag) |
|
| 172 | + * @param string $encoding |
|
| 173 | + * @return string |
|
| 174 | + * @see http://www.php.net/manual/function.htmlentities.php |
|
| 175 | + * @api |
|
| 176 | + */ |
|
| 177 | + protected function secure($value, $keepQuotes = false, $encoding = 'UTF-8') |
|
| 178 | + { |
|
| 179 | + $flags = $keepQuotes ? ENT_NOQUOTES : ENT_COMPAT; |
|
| 180 | + return htmlspecialchars($value, $flags, $encoding); |
|
| 181 | + } |
|
| 182 | + |
|
| 183 | + /** |
|
| 184 | + * Get the Vidi Module Loader. |
|
| 185 | + * |
|
| 186 | + * @return object|ModuleLoader |
|
| 187 | + */ |
|
| 188 | + protected function getModuleLoader() |
|
| 189 | + { |
|
| 190 | + return GeneralUtility::makeInstance(ModuleLoader::class); |
|
| 191 | + } |
|
| 192 | + |
|
| 193 | + /** |
|
| 194 | + * @return object|IconFactory |
|
| 195 | + */ |
|
| 196 | + protected function getIconFactory() |
|
| 197 | + { |
|
| 198 | + return GeneralUtility::makeInstance(IconFactory::class); |
|
| 199 | + } |
|
| 200 | + |
|
| 201 | + /** |
|
| 202 | + * @return object|LanguageService |
|
| 203 | + */ |
|
| 204 | + protected function getLanguageService() |
|
| 205 | + { |
|
| 206 | + return GeneralUtility::makeInstance(LanguageService::class); |
|
| 207 | + } |
|
| 208 | 208 | } |
@@ -61,7 +61,7 @@ |
||
| 61 | 61 | { |
| 62 | 62 | if (is_string($configuration)) { |
| 63 | 63 | $configuration = $legacyParameterConfiguration; |
| 64 | - trigger_error('ColumnRendererAbstract: first parameter must now be an array. Please edit me in ' . get_class($this), E_USER_DEPRECATED); |
|
| 64 | + trigger_error('ColumnRendererAbstract: first parameter must now be an array. Please edit me in '.get_class($this), E_USER_DEPRECATED); |
|
| 65 | 65 | } |
| 66 | 66 | $this->configuration = $configuration; |
| 67 | 67 | } |