Oprava nekterych veci rozbitych pri prechodu na novy system carovych kodu
[mirrors/SokoMan.git] / index.php
index b90738f1ff2884e1d79c671e3229ce5ba29ec1c8..ced77fb406f9bf3bbfdbe837fbc54ea802fc61f9 100755 (executable)
--- a/index.php
+++ b/index.php
@@ -357,9 +357,10 @@ EOF;
 
        function table_add_relations(&$table, $class, $suffix_relations='_relations') {
                $where_url = '%d/?where[%c]==%v';
+               $insert_url = '%d/new?insert[%c]=%v';
                $relations = array( //TODO: Autodetect??? //TODO: Add [edit] link to all classes
                        'model' => array(
-                               'model_id' => array(array('item',$where_url),array('edit','model/%v/edit/')),
+                               'model_id' => array(array('item',$where_url),array('barcode',$where_url),array('edit','model/%v/edit/'),array('barcode',$insert_url)),
                                'model_barcode' => array(array('store','assistant/%d?barcode=%v')),
                                'barcode_name' => array(array('store','assistant/%d?barcode=%v')),
                                'model_name' => array(array('google','http://google.com/search?q=%v')) //TODO: add manufacturer to google query
@@ -457,6 +458,8 @@ EOF;
 
        function table_hide_columns(&$table, $class) { //TODO: Move to build_query_select() !!! :-)))
                $fields_hide = array(
+                       'model' => array('barcode_name'),
+                       'barcode' => array('model_price_in','model_price_out','model_reserve','producer_name','producer_note','model_eshop_hide','category_name','model_countable','model_descript'),
                        'item' => array('model_descript','model_price_in','model_price_out','barcode_name','model_barcode','model_countable','model_reserve','model_eshop_hide','room_descript','room_author','producer_name','producer_note','vendor_note','location_author','location_gps','location_description')
                );
                //print_r($table); die();
@@ -558,9 +561,14 @@ EOF;
                //echo('<pre>'); print_r($selectbox);
                //echo('<pre>'); print_r($current);
                $update = false;
+               $current_new=array();
                if(is_array($current)) {
                        $update = true;
-                       $current = array_shift($current);
+                       $current_new = array_merge($current_new,array_shift($current));
+               }
+               if(isset($_GET['insert']) && is_array($_GET['insert'])) {
+                       $update = true;
+                       $current_new = array_merge($current_new,$_GET['insert']);
                }
 
                if(!is_array($hidecols)) $hidecols = array();
@@ -573,7 +581,7 @@ EOF;
                }
 
                if(!is_array($parts) || in_array('inputs', $parts))
-                       $html.=$this->render_insert_inputs($class,$columns,$selectbox,$current,$hidecols,$update);
+                       $html.=$this->render_insert_inputs($class,$columns,$selectbox,$current_new,$hidecols,$update);
 
                if(!is_array($parts) || in_array('foot', $parts)) {
                        $html .= '</div></span><br style="clear:both" />';
@@ -589,7 +597,7 @@ EOF;
 EOF;
                        }
 
-                       $btn = is_array($current) ? 'UPDATE' : 'INSERT'; //TODO: $current may be set even when inserting...
+                       $btn = count($current_new)>0 ? 'UPDATE' : 'INSERT'; //TODO: $current may be set even when inserting...
                        $html.=$this->input(false, $btn, 'submit');
                        $html.='</form>';
                }
@@ -628,10 +636,16 @@ class Sklad_DB extends PDO {
                        'item'  => array('barcode', 'model', 'category', 'producer', 'vendor', 'room', 'location', 'status'),
                        'model' => array('category', 'producer')
                ); //TODO Autodetect using foreign keys?
+               $join2 = array(
+                       'model' => array('barcode'=>'model_id')
+               );
                $fields_search = array(
                        'item'  => array('item_id','item_serial','model_name','barcode_name','model_barcode','model_descript','producer_name','vendor_name'),
                        'model' => array('model_id','model_name','barcode_name','model_barcode','model_descript','producer_name')
                ); //TODO Autodetect
+               $group_concat = array(
+                       'model' => array('barcode_name'=>'model_id')
+               );
 
                //Init
                if(is_array($where)) foreach($where as $key => $value) $where[$key] = $key.' '.$value; //TODO: escape SQLi!!!
@@ -639,10 +653,20 @@ class Sklad_DB extends PDO {
                //Escaping
                $class = $this->escape($class);
 
+               //GROUP_CONCAT
+               $group_concat_query = '';
+               $group_by = '';
+               if(isset($group_concat[$class])) foreach($group_concat[$class] as $gc => $gb) {
+                       $group_concat_query .= ",group_concat($gc separator ', ')";
+                       $group_by .= "GROUP BY $gb\n";
+               }
+
                //SELECT
-               $sql="SELECT * FROM `$class`\n";
+               $sql="SELECT *$group_concat_query FROM `$class`\n";
+               //$sql="SELECT * FROM `$class`\n";
                //JOIN
                if(isset($join[$class])) foreach($join[$class] as $j) $sql .= "LEFT JOIN `$j` USING($j$suffix_id)\n";
+               if(isset($join2[$class])) foreach($join2[$class] as $j => $c) $sql .= "LEFT JOIN `$j` USING($c)\n";
                //WHERE/REGEXP
                if($search) {
                        $search = $this->quote($search);
@@ -654,6 +678,10 @@ class Sklad_DB extends PDO {
                if(!$history && $this->contains_history($class)) $where[] = $class.'_valid_till=0';
 
                if($where) $sql .= 'WHERE ('.implode(') AND (', $where).")\n";
+
+               //GROUP BY
+               $sql.=$group_by;
+
                //ORDER
                if(!$order) $order = $class.$suffix_id.' DESC';
                if($this->contains_history($class)) $order .= ",${class}_valid_from DESC";
This page took 0.132206 seconds and 4 git commands to generate.