2012-06-25 15:04:51 +02:00
< ? php
2012-07-02 18:56:13 +02:00
class AdmAchievement extends AchAchievement implements ADM {
use AdmDispatcher ;
2012-06-25 15:04:51 +02:00
function AdmAchievement ( $data , $parent ) {
2012-07-02 18:56:13 +02:00
$this -> init ();
2012-06-25 15:04:51 +02:00
parent :: __construct ( $data , $parent );
}
2012-07-02 18:56:13 +02:00
protected function makeChild ( $d ) {
2012-06-25 15:04:51 +02:00
return new AdmPerk ( $d , $this );
}
2012-07-02 18:56:13 +02:00
#@overrides AdmDispatcher::insertNode()
function insertNode ( $n ) {
2012-06-25 15:04:51 +02:00
$n -> insert ();
2012-07-02 18:56:13 +02:00
$this -> addOpen ( $n );
2012-06-25 15:04:51 +02:00
}
function delete_me () {
global $DBc ;
$DBc -> sqlQuery ( " DELETE FROM ach_achievement WHERE aa_id=' " . $this -> getID () . " ' " );
$DBc -> sqlQuery ( " DELETE FROM ach_player_achievement WHERE apa_id=' " . $this -> getID () . " ' " );
$DBc -> sqlQuery ( " DELETE FROM ach_achievement_lang WHERE NOT EXISTS (SELECT * FROM ach_achievement WHERE aa_id=aal_achievement) " );
2012-07-02 18:56:13 +02:00
$iter = $this -> getIterator ();
while ( $iter -> hasNext ()) {
$curr = $iter -> getNext ();
$curr -> delete_me ();
$this -> removeChild ( $curr -> getID ());
2012-06-25 15:04:51 +02:00
}
}
function update () {
global $DBc ;
2012-07-02 18:56:13 +02:00
$DBc -> sqlQuery ( " UPDATE ach_achievement SET aa_category=' " . $this -> getCategory () . " ',aa_parent=NULL,aa_tie_race= " . mkn ( $this -> getTieRace ()) . " ,aa_tie_cult= " . mkn ( $this -> getTieCult ()) . " ,aa_tie_civ= " . mkn ( $this -> getTieCiv ()) . " ,aa_image=' " . mysql_real_escape_string ( $this -> getImage ()) . " ',aa_dev=' " . $this -> getDev () . " ' WHERE aa_id=' " . $this -> getID () . " ' " );
2012-06-25 15:04:51 +02:00
#MISSING: update lang entry
2012-07-02 18:56:13 +02:00
$DBc -> sqlQuery ( " INSERT INTO ach_achievement_lang (aal_achievement,aal_lang,aal_name,aal_template) VALUES (' " . $this -> getID () . " ','en',' " . mysql_real_escape_string ( $this -> getName ()) . " ', " . mkn ( $this -> getTemplate ()) . " ) ON DUPLICATE KEY UPDATE aal_name=' " . mysql_real_escape_string ( $this -> getName ()) . " ',aal_template= " . mkn ( $this -> getTemplate ()) . " " );
2012-06-25 15:04:51 +02:00
}
function insert () {
2012-07-02 18:56:13 +02:00
global $DBc ;
2012-06-25 15:04:51 +02:00
2012-07-02 18:56:13 +02:00
$this -> dev = 1 ;
2012-06-25 15:04:51 +02:00
2012-07-02 18:56:13 +02:00
$DBc -> sqlQuery ( " INSERT INTO ach_achievement (aa_category,aa_parent,aa_tie_race,aa_tie_cult,aa_tie_civ,aa_image,aa_dev) VALUES (' " . $this -> getCategory () . " ',NULL, " . mkn ( $this -> getTieRace ()) . " , " . mkn ( $this -> getTieCult ()) . " , " . mkn ( $this -> getTieCiv ()) . " ,' " . mysql_real_escape_string ( $this -> getImage ()) . " ','1') " );
$id = mysql_insert_id ();
$this -> setID ( $id );
2012-06-25 15:04:51 +02:00
2012-07-02 18:56:13 +02:00
$DBc -> sqlQuery ( " INSERT INTO ach_achievement_lang (aal_achievement,aal_lang,aal_name,aal_template) VALUES (' " . $this -> getID () . " ','en',' " . mysql_real_escape_string ( $this -> getName ()) . " ', " . mkn ( $this -> getTemplate ()) . " ) " );
2012-06-25 15:04:51 +02:00
}
function setCategory ( $c ) {
$this -> category = $c ;
}
function setTieRace ( $t ) {
$this -> tie_race = $t ;
}
function setTieCiv ( $t ) {
$this -> tie_civ = $t ;
}
function setTieCult ( $t ) {
$this -> tie_cult = $t ;
}
function setImage ( $i ) {
$this -> image = $i ;
}
function setName ( $n ) {
$this -> name = $n ;
}
2012-07-02 18:56:13 +02:00
function setTemplate ( $t ) {
2012-06-25 15:04:51 +02:00
$this -> template = $t ;
}
}
?>