use parameter for locked Achievements to prevent caching problems (Issue #155)
This commit is contained in:
parent
8483e27ade
commit
f36101a9ca
2 changed files with 16 additions and 8 deletions
|
|
@ -214,7 +214,7 @@
|
||||||
* @param string $achievementUrl URL-title of the Achievement
|
* @param string $achievementUrl URL-title of the Achievement
|
||||||
* @param string $action Action for processing the media
|
* @param string $action Action for processing the media
|
||||||
*/
|
*/
|
||||||
public function achievement($seminaryUrl, $achievementUrl)
|
public function achievement($seminaryUrl, $achievementUrl, $locked=null)
|
||||||
{
|
{
|
||||||
// Get Seminary
|
// Get Seminary
|
||||||
$seminary = $this->Seminaries->getSeminaryByUrl($seminaryUrl);
|
$seminary = $this->Seminaries->getSeminaryByUrl($seminaryUrl);
|
||||||
|
|
@ -226,12 +226,20 @@
|
||||||
$achievement = $this->Achievements->getAchievementByUrl($seminary['id'], $achievementUrl);
|
$achievement = $this->Achievements->getAchievementByUrl($seminary['id'], $achievementUrl);
|
||||||
|
|
||||||
// Get media
|
// Get media
|
||||||
$index = '';
|
switch($locked)
|
||||||
if(is_null($character) || !$this->Achievements->hasCharacterAchievedAchievement($achievement['id'], $character['id'])) {
|
{
|
||||||
$index = 'unachieved_achievementsmedia_id';
|
case null:
|
||||||
}
|
if(is_null($character) || !$this->Achievements->hasCharacterAchievedAchievement($achievement['id'], $character['id'])) {
|
||||||
else {
|
throw new \nre\exceptions\AccessDeniedException();
|
||||||
$index = 'achieved_achievementsmedia_id';
|
}
|
||||||
|
$index = 'achieved_achievementsmedia_id';
|
||||||
|
break;
|
||||||
|
case 'locked':
|
||||||
|
$index = 'unachieved_achievementsmedia_id';
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new \nre\exceptions\ParamsNotValidException($locked);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
if(is_null($achievement[$index])) {
|
if(is_null($achievement[$index])) {
|
||||||
throw new \nre\exceptions\IdNotFoundException($achievementUrl);
|
throw new \nre\exceptions\IdNotFoundException($achievementUrl);
|
||||||
|
|
|
||||||
|
|
@ -63,7 +63,7 @@
|
||||||
<?php foreach($unachievedAchievements as &$achievement) : ?>
|
<?php foreach($unachievedAchievements as &$achievement) : ?>
|
||||||
<li class="cf">
|
<li class="cf">
|
||||||
<?php if(!is_null($achievement['unachieved_achievementsmedia_id'])) : ?>
|
<?php if(!is_null($achievement['unachieved_achievementsmedia_id'])) : ?>
|
||||||
<img src="<?=$linker->link(array('media','achievement',$seminary['url'],$achievement['url']))?>" />
|
<img src="<?=$linker->link(array('media','achievement',$seminary['url'],$achievement['url'],'locked'))?>" />
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
<h3 id="<?=$achievement['url']?>"><?=(!$achievement['hidden']) ? $achievement['title'] : _('Secret Achievement')?></h3>
|
<h3 id="<?=$achievement['url']?>"><?=(!$achievement['hidden']) ? $achievement['title'] : _('Secret Achievement')?></h3>
|
||||||
<?php if(!$achievement['hidden']) : ?>
|
<?php if(!$achievement['hidden']) : ?>
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue