noalyss
Version-6.7.2
|
define Class fiche and fiche def, those class are using class attribut More...
Public Member Functions | |
__construct ($p_cn, $p_id=0) | |
Add ($array) | |
Add a fiche category thanks the element from the array you cannot add twice the same cat. name table : insert into fiche_def insert into attr_def. | |
count_category ($p_frd_id) | |
count the number of fiche_def (category) which has the frd_id (type of category) | |
Display () | |
Display category into a table. | |
DisplayAttribut ($str="") | |
Display all the attribut of the fiche_def. | |
get () | |
Get attribut of the fiche_def. | |
get_all () | |
Get all the fiche_def. | |
get_attr_min ($p_fiche_def_ref) | |
retrieve the mandatory field of the card model | |
get_by_category ($p_cat) | |
Get all the card where the fiche_def.frd_id is given in parameter. | |
get_by_type ($step=0) | |
Get all the card where the fiche_def.fd_id is given in parameter. | |
getAttribut () | |
Get attribut of a fiche_def. | |
HasAttribute ($p_attr) | |
Check in vw_fiche_def if a fiche has a attribut X. | |
input () | |
show the content of the form to create a new Fiche_Def_Ref | |
input_base () | |
show input for the basic attribute : label, class_base, create_account use only when we want to update | |
input_detail () | |
input_new () | |
InsertAttribut ($p_ad_id) | |
insert a new attribut for this fiche_def | |
myList () | |
list the card of a fd_id | |
remove () | |
remove all the card from a categorie after having verify that the card is not used and then remove also the category | |
RemoveAttribut ($array) | |
remove an attribut for this fiche_def | |
save_class_base ($p_label) | |
Save the class base. | |
save_description ($p_description) | |
save_order ($p_array) | |
save the order of a card, update the column jnt_fic_attr.jnt_order | |
SaveLabel ($p_label) | |
Save the label of the fiche_def. | |
set_autocreate ($p_label) | |
set the auto create accounting item for each card and save it into the database | |
Data Fields | |
$all | |
$attribut | |
$class_base | |
$cn | |
$create_account | |
$fiche_def | |
$id | |
$label |
define Class fiche and fiche def, those class are using class attribut
Definition at line 35 of file class_fiche_def.php.
Fiche_Def::__construct | ( | $ | p_cn, |
$ | p_id = 0 |
||
) |
Definition at line 45 of file class_fiche_def.php.
References cn.
{ $this->cn=$p_cn; $this->id=$p_id; }
Fiche_Def::Add | ( | $ | array | ) |
Add a fiche category thanks the element from the array you cannot add twice the same cat. name table : insert into fiche_def insert into attr_def.
$array | array index FICHE_REF nom_mod class_base |
!! (== fiche_def_ref.frd_id if (! isset ($p_FICHE_REF) || strlen($p_FICHE_REF) == 0 ) { echo alert (_('Vous devez choisir une categorie')); return 1; } $fiche_Def_ref=new Fiche_Def_Ref($this->cn,$p_FICHE_REF); $fiche_Def_ref->Get();
build the sql request for fiche_def and insert into fiche_def if p_class_base is null get the default class base from fiche_def_ref if ( sql_string($p_class_base) == null ) { // p_class is null So we take the default one $p_class_base=$fiche_Def_ref->frd_class_base; } /* check if the cat. name already exists
Definition at line 197 of file class_fiche_def.php.
References $array, $count, $fd_id, $order, $Res, $sql, alert(), cn, echo, get_attr_min(), sql_string(), and trim().
{ foreach ( $array as $key=>$element ) { ${"p_$key"}=$element; } // Format correctly the name of the cat. of card $p_nom_mod=sql_string($p_nom_mod); // Name can't be empty if ( strlen(trim($p_nom_mod)) == 0 ) { alert (_('Le nom de la catégorie ne peut pas être vide')); return 1; } /**!! (== fiche_def_ref.frd_id if (! isset ($p_FICHE_REF) || strlen($p_FICHE_REF) == 0 ) { echo alert (_('Vous devez choisir une categorie')); return 1; } $fiche_Def_ref=new Fiche_Def_Ref($this->cn,$p_FICHE_REF); $fiche_Def_ref->Get(); // build the sql request for fiche_def // and insert into fiche_def // if p_class_base is null get the default class base from // fiche_def_ref if ( sql_string($p_class_base) == null ) { // p_class is null // So we take the default one $p_class_base=$fiche_Def_ref->frd_class_base; } /* check if the cat. name already exists */ $sql="select count(*) from fiche_Def where upper(fd_label)=upper($1)"; $count=$this->cn->get_value($sql,array(trim($p_nom_mod))); if ($count != 0 ) { echo alert (_('Catégorie existante')); return 1; } // Set the value of fiche_def.fd_create_account // automatic creation for 'poste comptable' if ( isset($p_create) && strlen(trim($p_class_base)) != 0) $p_create='true'; else $p_create='false'; // Class is valid ? if ( sql_string($p_class_base) != null || strpos(',',$p_class_base) != 0 ) { // p_class is a valid number $sql="insert into fiche_def(fd_label,fd_class_base,frd_id,fd_create_account,fd_description) values ($1,$2,$3,$4,$5) returning fd_id"; $fd_id=$this->cn->get_value($sql,array($p_nom_mod,$p_class_base,$p_FICHE_REF,$p_create,$p_fd_description)); // p_class must be added to tmp_pcmn if it is a single accounting if ( strpos(',',$p_class_base) ==0) { $sql="select account_add($1,$2)"; $Res=$this->cn->exec_sql($sql,array($p_class_base,$p_nom_mod)); } // Get the fd_id $fd_id=$this->cn->get_current_seq('s_fdef'); // update jnt_fic_attr $sql=sprintf("insert into jnt_fic_attr(fd_id,ad_id,jnt_order) values (%d,%d,10)",$fd_id,ATTR_DEF_ACCOUNT); $Res=$this->cn->exec_sql($sql); } else { //There is no class base not even as default $sql="insert into fiche_def(fd_label,frd_id,fd_create_account,fd_description) values ($1,$2,$3,$4) returning fd_id"; $this->id=$this->cn->get_value($sql,array($p_nom_mod,$p_FICHE_REF,$p_create,$p_fd_description)); // Get the fd_id $fd_id=$this->cn->get_current_seq('s_fdef'); } // Get the default attr_def from attr_min $def_attr=$this->get_attr_min($p_FICHE_REF); //if defaut attr not null // build the sql insert for the table attr_def if (sizeof($def_attr) != 0 ) { // insert all the mandatory fields into jnt_fiche_attr $jnt_order=10; foreach ( $def_attr as $i=>$v) { $order=$jnt_order; if ( $v['ad_id'] == ATTR_DEF_NAME ) $order=0; $count=$this->cn->get_value("select count(*) from jnt_fic_attr where fd_id=$1 and ad_id=$2",array($fd_id,$v['ad_id'])); if ($count == 0) { $sql=sprintf("insert into jnt_fic_Attr(fd_id,ad_id,jnt_order) values (%d,%s,%d)", $fd_id,$v['ad_id'],$order); $this->cn->exec_sql($sql); $jnt_order+=10; } } } $this->id=$fd_id; return 0; }//--------------end function Add ----------------------------
Fiche_Def::count_category | ( | $ | p_frd_id | ) |
count the number of fiche_def (category) which has the frd_id (type of category)
$p_frd_id | is the frd_id in constant.php the FICHE_TYPE_ |
Definition at line 751 of file class_fiche_def.php.
Display category into a table.
Definition at line 167 of file class_fiche_def.php.
References $_GET, $order, $res, $tab, $url, cn, and HtmlInput\get_to_string().
{ $tab = new Sort_Table(); $url = HtmlInput::get_to_string(array('ac', 'gDossier')); $tab->add("Nom de fiche", $url, "order by fd_label asc", "order by fd_label desc", "na", "nd"); $tab->add("Basé sur le poste comptable", $url, "order by fd_class_base asc", "order by fd_class_base desc", "pa", "pd"); $tab->add("Calcul automatique du poste comptable", $url, "order by fd_create_account asc", "order by fd_create_account desc", "ca", "cd"); $tab->add("Basé sur le modèle", $url, "order by frd_text asc", "order by frd_text desc", "ma", "md"); $order = (isset($_GET['ord'])) ? $tab->get_sql_order($_GET["ord"]) : $tab->get_sql_order("na"); $res = $this->cn->exec_sql("SELECT fd_id, fd_class_base, fd_label, fd_create_account, fiche_def_ref.frd_id, frd_text , fd_description FROM fiche_def join fiche_def_ref on (fiche_def.frd_id=fiche_def_ref.frd_id) $order "); require_once 'template/fiche_def_list.php'; }
Fiche_Def::DisplayAttribut | ( | $ | str = "" | ) |
Display all the attribut of the fiche_def.
$str | give the action possible values are remove, empty |
Definition at line 482 of file class_fiche_def.php.
References $a, $class, $l, $order, $r, $Res, $str, cn, Database\fetch_array(), and Database\num_row().
Referenced by input_detail().
{ if ( $this->id == 0 ) return ; $this->cn->exec_sql('select fiche_attribut_synchro($1)',array($this->id)); $MaxLine=sizeof($this->attribut); $r="<TABLE>"; $r.="<tr>".th('Nom attribut').th('').th('Ordre','style="text-align:right"').'</tr>'; // Display each attribute $add_action=""; for ($i=0;$i<$MaxLine;$i++) { $class="even"; if ( $i % 2 == 0 ) $class="odd"; $r.='<TR class="'.$class.'"><td>'; // Can change the name if ( $this->attribut[$i]->ad_id == ATTR_DEF_NAME ) { continue; } else { if ( $str == "remove" ) { //Only for the not mandatory attribute (not defined in attr_min) if ( $this->cn->count_sql("select * from attr_min where frd_id=". $this->fiche_def." and ad_id = ".$this->attribut[$i]->ad_id) == 0 && $this->attribut[$i]->ad_id != ATTR_DEF_QUICKCODE && $this->attribut[$i]->ad_id != ATTR_DEF_ACCOUNT ) { $add_action=sprintf( '</TD><TD> Supprimer <input type="checkbox" name="chk_remove[]" value="%d">', $this->attribut[$i]->ad_id); } else $add_action="</td><td>"; } // The attribut. $a=sprintf('%s ', $this->attribut[$i]->ad_text); $r.=$a.$add_action; /*---------------------------------------- */ /* ORDER OF THE CARD */ /*---------------------------------------- */ $order=new IText(); $order->name='jnt_order'.$this->attribut[$i]->ad_id; $order->size=3; $order->value=$this->attribut[$i]->jnt_order; $r.='</td><td> '.$order->input(); } $r.= '</td></tr>'; } // Show the possible attribute which are not already attribute of the model // of card $Res=$this->cn->exec_sql("select ad_id,ad_text from attr_def where ad_id not in (select ad_id from fiche_def natural join jnt_fic_attr where fd_id=$1) order by ad_text",array($this->id) ); $M=Database::num_row($Res); // Show the unused attribute $r.='<TR> <TD>'; $r.= '<SELECT NAME="ad_id">'; for ($i=0;$i<$M;$i++) { $l=Database::fetch_array($Res,$i); $a=sprintf('<OPTION VALUE="%s"> %s', $l['ad_id'],$l['ad_text']); $r.=$a; } $r.='</SELECT>'; $r.="</TABLE>"; return $r; }
Fiche_Def::get | ( | ) |
Get attribut of the fiche_def.
Definition at line 104 of file class_fiche_def.php.
References $Max, $Ret, $row, $sql, cn, Database\fetch_array(), label, and Database\num_row().
Referenced by myList().
{ if ( $this->id == 0 ) return 0; /* $this->cn->exec_sql('select fiche_attribut_synchro($1)', array($this->id)); */ $sql="select * from fiche_def ". " where fd_id=".$this->id; $Ret=$this->cn->exec_sql($sql); if ( ($Max=Database::num_row($Ret)) == 0 ) return ; $row=Database::fetch_array($Ret,0); $this->label=$row['fd_label']; $this->class_base=$row['fd_class_base']; $this->fiche_def=$row['frd_id']; $this->create_account=$row['fd_create_account']; $this->fd_description=$row['fd_description']; }
Get all the fiche_def.
Definition at line 129 of file class_fiche_def.php.
References $Max, $Ret, $row, $sql, cn, Database\fetch_array(), and Database\num_row().
{ $sql="select * from fiche_def "; $Ret=$this->cn->exec_sql($sql); if ( ($Max=Database::num_row($Ret)) == 0 ) return ; for ( $i = 0; $i < $Max;$i++) { $row=Database::fetch_array($Ret,$i); $this->all[$i]=new Fiche_Def($this->cn,$row['fd_id']); $this->all[$i]->label=$row['fd_label']; $this->all[$i]->class_base=$row['fd_class_base']; $this->all[$i]->fiche_def=$row['frd_id']; $this->all[$i]->create_account=$row['fd_create_account']; } }
Fiche_Def::get_attr_min | ( | $ | p_fiche_def_ref | ) |
retrieve the mandatory field of the card model
$p_fiche_def_ref |
Definition at line 723 of file class_fiche_def.php.
References $array, $f, $Res, cn, Database\fetch_array(), and Database\num_row().
Referenced by Add().
{ // find the min attr for the fiche_def_ref $Sql="select ad_id,ad_text from attr_min natural join attr_def natural join fiche_def_ref where frd_id= $1"; $Res=$this->cn->exec_sql($Sql,array($p_fiche_def_ref)); $Num=Database::num_row($Res); // test the number of returned rows if ($Num == 0 ) return null; // Get Results & Store them in a array for ($i=0;$i<$Num;$i++) { $f=Database::fetch_array($Res,$i); $array[$i]['ad_id']=$f['ad_id']; $array[$i]['ad_text']=$f['ad_text']; } return $array; }
Fiche_Def::get_by_category | ( | $ | p_cat | ) |
Get all the card where the fiche_def.frd_id is given in parameter.
Definition at line 342 of file class_fiche_def.php.
References $all, $Max, $Ret, $row, $sql, cn, Database\fetch_array(), and Database\num_row().
{ $sql="select f_id,ad_value from fiche join fiche_def using(fd_id) join fiche_detail using(f_id) where ad_id=1 and frd_id=$1 order by 2 "; $Ret=$this->cn->exec_sql($sql,array($p_cat)); if ( ($Max=Database::num_row($Ret)) == 0 ) return null; $all[0]=new Fiche($this->cn); for ($i=0;$i<$Max;$i++) { $row=Database::fetch_array($Ret,$i); $t=new Fiche($this->cn,$row['f_id']); $t->getAttribut(); $all[$i]=$t; } return $all; }
Fiche_Def::get_by_type | ( | $ | step = 0 | ) |
Get all the card where the fiche_def.fd_id is given in parameter.
$step | = 0 we don't use the offset, page_size,... $step = 1 we use the jnr_bar_nav |
Definition at line 319 of file class_fiche_def.php.
References $_GET, $offset, $Ret, $sql, $step, and cn.
{ $sql="select f_id,ad_value from fiche join fiche_detail using(f_id) where ad_id=1 and fd_id=$1 order by 2"; // we use navigation_bar if ($step == 1 && $_SESSION['g_pagesize'] != -1 ) { $offset=(isset($_GET['offset']))?$_GET['offset']:0; $step=$_SESSION['g_pagesize']; $sql.=" offset $offset limit $step"; } $Ret=$this->cn->get_array($sql,array($this->id)); return $Ret; }
Get attribut of a fiche_def.
Definition at line 75 of file class_fiche_def.php.
References $Max, $Ret, $row, $sql, cn, Database\fetch_array(), and Database\num_row().
{ $sql="select * from jnt_fic_attr ". " natural join attr_def where fd_id=".$this->id. " order by jnt_order"; $Ret=$this->cn->exec_sql($sql); if ( ($Max=Database::num_row($Ret)) == 0 ) return ; for ($i=0;$i < $Max;$i++) { $row=Database::fetch_array($Ret,$i); $t = new Fiche_Attr($this->cn); $t->ad_id=$row['ad_id']; $t->ad_text=$row['ad_text']; $t->jnt_order=$row['jnt_order']; $t->ad_size=$row['ad_size']; $t->ad_type=$row['ad_type']; $t->ad_extra=$row['ad_extra']; $this->attribut[$i]=clone $t; } return $this->attribut; }
Fiche_Def::HasAttribute | ( | $ | p_attr | ) |
Check in vw_fiche_def if a fiche has a attribut X.
$p_attr | attribut to check |
Definition at line 156 of file class_fiche_def.php.
References cn.
{ return ($this->cn->count_sql("select * from vw_fiche_def where ad_id=$p_attr and fd_id=".$this->id)>0)?true:false; }
Fiche_Def::input | ( | ) |
show the content of the form to create a new Fiche_Def_Ref
Definition at line 52 of file class_fiche_def.php.
References $class_base, $iradio, and cn.
{ $ref=$this->cn->get_array("select * from fiche_def_ref order by frd_text"); $iradio=new IRadio(); /* the accounting item */ $class_base=new IPoste('class_base'); $class_base->set_attribute('ipopup','ipop_account'); $class_base->set_attribute('account','class_base'); $class_base->set_attribute('label','acc_label'); $f_class_base=$class_base->input(); $fd_description=new ITextarea('fd_description'); $fd_description->width=80; $fd_description->heigh=4; $fd_description->style='style="vertical-align:text-top"'; require_once ('template/fiche_def_input.php'); return; }
show input for the basic attribute : label, class_base, create_account use only when we want to update
Definition at line 450 of file class_fiche_def.php.
References $ck, $class_base, $label, $r, and label.
Referenced by input_detail().
{ $r=""; $r.=_('Label'); $label=new IText('label',$this->label); $r.=$label->input(); $r.='<br>'; /* the accounting item */ $class_base=new IPoste('class_base',$this->class_base); $class_base->set_attribute('ipopup','ipop_account'); $class_base->set_attribute('account','class_base'); $class_base->set_attribute('label','acc_label'); $fd_description=new ITextarea('fd_description',$this->fd_description); $fd_description->width=80; $fd_description->heigh=4; $fd_description->style='style="vertical-align:text-top"'; $r.=_('Poste Comptable de base').' : '; $r.=$class_base->input(); $r.='<span id="acc_label"></span><br>'; $r.='<br/>'; $r.=" Description ".$fd_description->input(); /* auto Create */ $r.='<br/>'; $ck=new ICheckBox('create'); $ck->selected=($this->create_account=='f')?false:true; $r.=_('Chaque fiche aura automatiquement son propre poste comptable : '); $r.=$ck->input(); return $r; }
Definition at line 756 of file class_fiche_def.php.
References $r, DisplayAttribut(), h(), HtmlInput\hidden(), input_base(), label, onclick, and HtmlInput\submit().
{ $r = ""; // Save the label $this->get(); $this->GetAttribut(); $r.= '<H2 class="info">' . $this->id . " " . h($this->label) . '</H2>'; $r.='<fieldset><legend>Données générales</legend>'; /* show the values label class_base and create account */ $r.='<form method="post">'; $r.=dossier::hidden(); $r.=HtmlInput::hidden("fd_id", $this->id); $r.=HtmlInput::hidden("p_action", "fiche"); $r.= $this->input_base(); $r.='<hr>'; $r.=HtmlInput::submit('change_name', _('Sauver')); $r.='</form>'; $r.='</fieldset>'; /* attributes */ $r.='<fieldset><legend>Détails</legend>'; $r.= '<FORM method="POST">'; $r.=dossier::hidden(); $r.=HtmlInput::hidden("fd_id", $this->id); $r.= $this->DisplayAttribut("remove"); $r.= HtmlInput::submit('add_line', _('Ajoutez cet élément')); $r.= HtmlInput::submit("save_line", _("Sauvez")); $r.=HtmlInput::submit('remove_cat', _('Effacer cette catégorie'), 'onclick="return confirm(\'' . _('Vous confirmez ?') . '\')"'); // if there is nothing to remove then hide the button if (strpos($r, "chk_remove") != 0) { $r.=HtmlInput::submit('remove_line', _("Enleve les éléments cochés"), "onclick=\"return confirm('Vous confirmez?')\""); } $r.= "</form>"; $r.=" <p class=\"notice\"> " . _("Attention : il n'y aura pas de demande de confirmation pour enlever les attributs sélectionnés. Il ne sera pas possible de revenir en arrière") . "</p>"; $r.='</fieldset>'; return $r; }
Definition at line 797 of file class_fiche_def.php.
References echo, HtmlInput\hidden(), and HtmlInput\submit().
Fiche_Def::InsertAttribut | ( | $ | p_ad_id | ) |
insert a new attribut for this fiche_def
$p_ad_id | id of the attribut |
Definition at line 618 of file class_fiche_def.php.
References $max, $Res, $sql, and cn.
{ if ( $this->id == 0 ) return; /* ORDER */ $this->GetAttribut(); $max=sizeof($this->attribut)*15; // Insert a new attribute for the model // it means insert a row in jnt_fic_attr $sql=sprintf("insert into jnt_fic_attr (fd_id,ad_id,jnt_order) values (%d,%d,%d)", $this->id,$p_ad_id,$max); $Res=$this->cn->exec_sql($sql); // update all the existing card }
list the card of a fd_id
Definition at line 368 of file class_fiche_def.php.
References $_GET, $_REQUEST, $bar, $Max, $max_line, $offset, $page, $Res, $step, $str, $str_dossier, cn, echo, Database\fetch_array(), get(), h(), HtmlInput\hidden(), label, navigation_bar(), Database\num_row(), and HtmlInput\submit().
{ $this->get(); echo '<H2 class="info">'.$this->id." ".$this->label.'</H2>'; $step=$_SESSION['g_pagesize']; $sql_limit=""; $sql_offset=""; $bar=""; if ( $step != -1 ) { $page=(isset($_GET['page']))?$_GET['page']:1; $offset=(isset($_GET['offset']))?$_GET['offset']:0; $max_line=$this->cn->count_sql("select f_id,ad_value from fiche join fiche_detail using (f_id) where fd_id='".$this->id."' and ad_id=".ATTR_DEF_NAME." order by f_id"); $sql_limit=" limit ".$step; $sql_offset=" offset ".$offset; $bar=navigation_bar($offset,$max_line,$step,$page); } // Get all name the cards of the select category // 1 for attr_def.ad_id is always the name $Res=$this->cn->exec_sql("select f_id,vw_name,quick_code from ". " vw_fiche_attr ". " where fd_id='".$this->id. "' order by f_id $sql_offset $sql_limit "); $Max=Database::num_row($Res); echo $bar; $str=""; // save the url // with offet &offset=15&step=15&page=2&size=15 if ( $_SESSION['g_pagesize'] != -1) { $str=sprintf("&offset=%s&step=%s&page=%s&size=%s", $offset, $step, $page, $max_line); } echo '<FORM METHOD="POST" action="?p_action=fiche&action=vue'.$str.'">'; echo HtmlInput::hidden('ac',$_REQUEST['ac']); echo dossier::hidden(); echo HtmlInput::hidden("fiche",$this->id); echo HtmlInput::submit('add','Ajout fiche'); echo '</FORM>'; $str_dossier=dossier::get(); echo '<table>'; for ( $i = 0; $i < $Max; $i++) { $l_line=Database::fetch_array($Res,$i); if ( $i%2 == 0) echo '<TR class="odd">'; else echo '<TR class="even">'; $span_mod='<TD><A href="?p_action=fiche&'.$str_dossier. '&action=detail&fiche_id='.$l_line['f_id'].$str.'&fiche='. $_REQUEST['fiche'].'&ac='.$_REQUEST['ac'].'">'.$l_line['quick_code'] .'</A></TD>'; echo $span_mod.'<TD>'.h($l_line['vw_name'])."</TD>"; echo '</tr>'; } echo '</table>'; echo '<FORM METHOD="POST" action="?p_action=fiche&action=vue'.$str.'">'; echo HtmlInput::hidden('ac',$_REQUEST['ac']); echo dossier::hidden(); echo HtmlInput::hidden("fiche",$this->id); echo HtmlInput::submit('add','Ajout fiche'); echo '</FORM>'; echo $bar; }
remove all the card from a categorie after having verify that the card is not used and then remove also the category
Definition at line 684 of file class_fiche_def.php.
References $fiche, $sql, cn, and false.
{ $remain=0; /* get all the card */ $aFiche=fiche::get_fiche_def($this->cn,$this->id); if ( $aFiche != null ) { /* check if the card is used */ foreach ($aFiche as $dfiche) { $fiche=new Fiche($this->cn,$dfiche['f_id']); /* if the card is not used then remove it otherwise increment remains */ if ( $fiche->is_used() == false ) { $fiche->delete(); } else $remain++; } } /* if remains == 0 then remove cat */ if ( $remain == 0 ) { $sql='delete from jnt_fic_attr where fd_id=$1'; $this->cn->exec_sql($sql,array($this->id)); $sql='delete from fiche_def where fd_id=$1'; $this->cn->exec_sql($sql,array($this->id)); } return $remain; }
Fiche_Def::RemoveAttribut | ( | $ | array | ) |
remove an attribut for this fiche_def
array | of ad_id to remove |
Definition at line 636 of file class_fiche_def.php.
References $array, $sql, and cn.
{ foreach ($array as $ch) { $this->cn->start(); $sql="delete from jnt_fic_attr where fd_id=$1 ". " and ad_id=$2"; $this->cn->exec_sql($sql,array($this->id,$ch)); $sql="delete from fiche_detail where jft_id in ( select ". " jft_id from fiche_Detail ". " join fiche using(f_id) ". " where ". "fd_id = $1 and ". "ad_id=$2)"; $this->cn->exec_sql($sql,array($this->id,$ch)); $this->cn->commit(); } }
Fiche_Def::save_class_base | ( | $ | p_label | ) |
Save the class base.
$p_label | label |
Definition at line 598 of file class_fiche_def.php.
References $Res, $sql, cn, and sql_string().
{ if ( $this->id == 0 ) return; $p_label=sql_string($p_label); $sql="update fiche_def set fd_class_base=$1 ". "where fd_id=$2"; $Res=$this->cn->exec_sql($sql,array($p_label,$this->id)); }
Fiche_Def::save_description | ( | $ | p_description | ) |
Definition at line 608 of file class_fiche_def.php.
References cn.
{ if ( $this->id == 0) return; $this->cn->exec_sql("update fiche_def set fd_description=$1 where fd_id=$2",array($p_description,$this->id)); }
Fiche_Def::save_order | ( | $ | p_array | ) |
save the order of a card, update the column jnt_fic_attr.jnt_order
$p_array | containing the order |
Definition at line 660 of file class_fiche_def.php.
References $p_array, $row, $sql, cn, and id.
{ extract($p_array); $this->GetAttribut(); foreach ($this->attribut as $row) { if ( $row->ad_id == 1 ) continue; if ( ${'jnt_order'.$row->ad_id} <= 0 ) continue; $sql='update jnt_fic_attr set jnt_order=$1 where fd_id=$2 and ad_id=$3'; $this->cn->exec_sql($sql,array(${'jnt_order'.$row->ad_id}, $this->id, $row->ad_id)); } /* correct the order */ $this->cn->exec_sql('select attribute_correct_order()'); }
Fiche_Def::SaveLabel | ( | $ | p_label | ) |
Save the label of the fiche_def.
$p_label | label |
Definition at line 563 of file class_fiche_def.php.
References $Res, $sql, cn, sql_string(), and trim().
Fiche_Def::set_autocreate | ( | $ | p_label | ) |
set the auto create accounting item for each card and save it into the database
$p_label | true or false |
Definition at line 581 of file class_fiche_def.php.
Fiche_Def::$all |
Definition at line 43 of file class_fiche_def.php.
Referenced by get_by_category().
Fiche_Def::$attribut |
Definition at line 44 of file class_fiche_def.php.
Fiche_Def::$class_base |
Definition at line 40 of file class_fiche_def.php.
Referenced by input(), and input_base().
Fiche_Def::$cn |
Definition at line 37 of file class_fiche_def.php.
Fiche_Def::$create_account |
Definition at line 42 of file class_fiche_def.php.
Fiche_Def::$fiche_def |
Definition at line 41 of file class_fiche_def.php.
Fiche_Def::$id |
Definition at line 38 of file class_fiche_def.php.
Fiche_Def::$label |
Definition at line 39 of file class_fiche_def.php.
Referenced by input_base().