1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/noalyss_ynh.git synced 2024-09-03 19:46:20 +02:00
noalyss_ynh/sources/include/class_html_table.php

154 lines
4 KiB
PHP
Raw Normal View History

2015-09-27 00:35:53 +02:00
<?php
/*
* This file is part of NOALYSS.
*
* NOALYSS is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* NOALYSS is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with NOALYSS; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
// Copyright Author Dany De Bontridder danydb@aevalys.eu
/*!\file
* \brief contains HTML features
*/
class Html_Table
{
/**
* Receives a SQL command and returns a string with the HTML code
* to display it as a table.
* Simple table without any feature (link in certain cell, sort,...)
* @param $cn database object
* @param $a_col header of the column it is an array of array
* indexes are link, name,image, style
* @param $sql query to execute
* @param $table_style style of the table
* @parm $a_sql_var array variable for the $sql DEFAULT NULL
@code
static function test_me()
{
$cn=new Database(Dossier::id());
$order=" order by f_id desc ";
$url=HtmlInput::get_to_string(array("gDossier","test_select"));
if ( isset($_GET['sb']))
{
$order=" order by f_id";
$img="image/select1.gif";
}
else
{
$url=$url."&sb=as";
$img="image/select2.gif";
}
$sql="select f_id,name,quick_code from vw_client $order limit 10";
echo $sql;
echo Html_Table::sql2table($cn,
array(
array('name'=>'N° de fiche',
'style'=>'text-align:right',
'link'=>$url,
'image'=>$img),
array('name'=>'Nom',
'style'=>'text-align:right'),
array('name'=>'QuickCode')
)
,
$sql
);
}
@endcode
*/
static function sql2table($cn,$a_col,$sql,$table_style='class="result"',$a_sql_var=null)
{
$r='';
$r=sprintf('<table %s>',$table_style);
$r.='<tr>';
for ( $i=0;$i <count($a_col);$i++)
{
$content=h($a_col[$i]['name']);
$style=(isset($a_col[$i]['style']))?$a_col[$i]['style']:"";
if ( isset($a_col[$i]['image']) && $a_col[$i]['image'] != '')
{
$content=sprintf('<img src="%s" border="0"></img>%s',$a_col[$i]['image'],$content);
}
if ( isset($a_col[$i]['link']) )
{
$content=sprintf('<a href="%s">%s</a>',
$a_col[$i]['link'],
$content);
$r.="<th $style>$content</th>";
}
else
$r.= "<th $style>". h($content)."</th>";
}
$r.='</tr>';
$ret=$cn->exec_sql($sql,$a_sql_var);
for ($i=0;$i<Database::num_row($ret);$i++)
{
$r.='<tr>';
$row=Database::fetch_row($ret,$i);
for ($e=0;$e<count($row);$e++)
{
$style='';$content=h($row[$e]);
if ( isset($a_col[$e]['style']) )
$style=$a_col[$e]['style'];
if ( isset ($a_col[$e]['raw']))
$r.='<td $style>'.$row[$e].'</td>';
else
$r.=td($content,$style);
}
$r.='</tr>';
}
$r.='</table>';
return $r;
}
static function test_me()
{
$cn=new Database(Dossier::id());
$order=" order by f_id desc ";
$url=HtmlInput::get_to_string(array("gDossier","test_select"));
if ( isset($_GET['sb']))
{
$order=" order by f_id";
$img="image/select1.gif";
}
else
{
$url=$url."&sb=as";
$img="image/select2.gif";
}
$sql="select f_id,name,quick_code from vw_client $order limit 10";
echo $sql;
echo Html_Table::sql2table($cn,
array(
array('name'=>'N° de fiche',
'style'=>'text-align:right',
'link'=>$url,
'image'=>$img),
array('name'=>'Nom',
'style'=>'text-align:right'),
array('name'=>'QuickCode')
)
,
$sql
);
}
}