source: trunk/types/PointerOneToOne.php

Last change on this file was 36, checked in by george, 16 years ago
  • Opraveno: Různá chybová hlášení.
  • Upraveno: Zobrazení přímo skriptu a čísla řádku, ve kterém nastala chyba. Funkce již není přímo zobrazována.
File size: 3.6 KB
Line 
1<?php
2
3class TypePointerOneToOne extends TypeBase
4{
5 function GetTablePointerName($Type, $Item)
6 {
7 global $Database;
8
9 //print_r($Item);
10 $Columns = '';
11 $List = GetListDefinition($Type['Parameters'][0]);
12 $TargetTable = $List['TableName'];
13 //echo($TargetTable.'<');
14 //print_r($List);
15 foreach($List['Items'] as $Index => $ListItem)
16 {
17 //echo('ListItem');
18 //print_r($ListItem);
19 $Type = GetTypeDefinition($ListItem['Type']);
20 if($ListItem['VisibleInPointer'] == 1)
21 {
22 if($Type['ParentType'] == TypePointerOneToOneId)
23 {
24 //print_r($Type);
25 $DbResult = $Database->select(array('Database' => $List['Database'], 'Table' => $List['TableName'], 'Condition' => $List['IdName'].'='.$Item['Value']));
26 $DbRow = $DbResult->fetch_assoc();
27 $DefinitionItem = array('Name' => $Index, 'Type' => $Item['Type'], 'Caption' => $Item['TextBefore'], 'Value' => $DbRow[$Index], 'SourceTable' => $List['Id'], 'SourceItemId' => 0);
28 $SubTarget = $this->GetTablePointerName($Type, $DefinitionItem);
29 $Columns .= '"'.$SubTarget['Name'].' ",';
30 } else $Columns .= '`'.$ListItem['Name'].'`," ",';
31 }
32 }
33 $Columns = substr($Columns, 0, -1);
34 if($Columns == '') $Columns = '`'.$List['IdName'].'` AS `Name`, `'.$List['IdName'].'`';
35 else $Columns = 'CONCAT('.$Columns.') AS `Name`, `'.$List['IdName'].'`';
36 $DbResult = $Database->select(array('Database' => $List['Database'], 'Table' => $TargetTable, 'Columns' => $Columns, 'Condition' => $List['IdName'].'='.$Item['Value']));
37 //echo($Database->LastQuery);
38 if($DbResult->num_rows > 0)
39 {
40 return($DbResult->fetch_assoc());
41 } else return('');
42 }
43
44 function GetTablePointerNameList($Type, $Item)
45 {
46 global $Database;
47
48 $Columns = '';
49 $List = GetListDefinition($Type['Parameters'][0]);
50 $TargetTable = $List['TableName'];
51 foreach($List['Items'] as $ListItem)
52 if($ListItem['VisibleInPointer'] == 1) $Columns .= '`'.$ListItem['Name'].'`," ",';
53 $Columns = 'CONCAT('.substr($Columns, 0, -1).') AS Name, `'.$List['IdName'].'`';
54 $DbResult = $Database->select(array('Database' => $List['Database'], 'Table' => $TargetTable, 'Columns' => $Columns));
55 //echo($Database->LastQuery);
56 if($DbResult->num_rows > 0)
57 {
58
59 $Result = array(array('Name' => 'Žádný', 'Id' => 0));
60 while($DbRow = $DbResult->fetch_assoc())
61 $Result[] = $DbRow;
62 return($Result);
63 } else return(array());
64 }
65
66 function OnView($Item)
67 {
68 global $Database;
69
70 $Type = GetTypeDefinition($Item['Type']);
71 $List = GetListDefinition($Type['Parameters'][0]);
72 $TargetTable = $Type['Parameters'][0];
73 $TargetName = $this->GetTablePointerName($Type, $Item);
74 if($TargetName != '') $Output = '<a href="?Action=ViewItem&amp;Table='.$TargetTable.'&amp;Item='.$TargetName[$List['IdName']].'">'.$TargetName['Name'].'</a>';
75 else $Output = '';
76 return($Output);
77 }
78
79 function OnEdit($Item)
80 {
81 global $Database, $Types;
82
83 $Type = $Types[$Item['Type']];
84 $List = GetListDefinition($Type['Parameters'][0]);
85 $Output = '<select name="'.$Item['Name'].'">';
86 $TargetNameList = $this->GetTablePointerNameList($Type, $Item);
87 //echo($Database->LastQuery);
88 foreach($TargetNameList as $TargetName)
89 {
90 if($Item['Value'] == $TargetName[$List['IdName']]) $Selected = ' selected="1"'; else $Selected = '';
91 $Output .= '<option value="'.$TargetName[$List['IdName']].'"'.$Selected.'>'.$TargetName['Name'].'</option>';
92 }
93 $Output .= '</select>';
94 return($Output);
95 }
96
97 function OnLoad($Item)
98 {
99 return($_POST[$Item['Name']]);
100 }
101}
102
103?>
Note: See TracBrowser for help on using the repository browser.