Хранилища Subversion dreq

Редакция

Содержимое файла | Последнее изменение | Открыть журнал | RSS

Редакция Автор № строки Строка
3 sivan 1
<?php
2
/**
3
 * Description of lib
4
 *
5
 * @author Sinegovsky Ivan
6
 */
7
 
8
class request {
9
    function ListRequest(){//возвращает таблицу список запросов
10
        switch ($_GET['order']){
11
            case 'named':
12
                $order="ORDER BY `name` DESC";
13
                break;
14
            case 'nameu':
15
                $order="ORDER BY `name` ASC";
16
                break;
17
            case 'authord':
18
                $order="ORDER BY `author` DESC";
19
                break;
20
            case 'authoru':
21
                $order="ORDER BY `author` ASC";
22
                break;
23
            case 'statusd':
24
                $order="ORDER BY `status` DESC ";
25
                break;
26
            case 'statusu':
27
                $order="ORDER BY `status` ASC ";
28
                break;
29
            default:
30
                $order="ORDER BY `status` ASC ";
31
        }
32
        $rez="<table width='100%'><tr><td><b><a href='index.php?order=authord'>&#8595;</a>Заказчик<a href='index.php?order=authoru'>&#8593;</a></b></td><td><b><a href='index.php?order=named'>&#8595;</a> Название<a href='index.php?order=nameu'>&#8593;</a></b></td><td><b><a href='index.php?order=statusd'>&#8595;</a> Статус<a href='index.php?order=statusu'>&#8593;</a></b></td><td><b>Действия</b></td></tr>";
33
        $query='SELECT * FROM `requests` '.$order;
34
        $result=mysql_query($query);
35
        while($row=mysql_fetch_array($result)){
36
            $id=$row['id'];
37
            if($row['type']==0){$type='[статья]';}else{$type='[файл]';}
38
            $name="<a href='index.php?act=show&id=".$id."'>".$type." ".$row['name']."</a>";
39
            if ($row['status']){
40
                    $st="<span class='ok'>Готов</span>";
41
                    $act="<a href='".$row['url']."'>Получить</a>";
42
            }else{
43
                    $st="<span class='need'>Требуется</span>";
44
                    $act="<a href='index.php?act=make&id=".$id."'>Выполнить</a>";
45
            }
46
            //if($mode=='admin'){$act.=" <a style='color:red;text-decoration:none;' href='index.php?act=delete&id=".$id."'>[удалить]</a>";}
47
            $rez.="<tr><td>".$row['author']."</td><td>".$name."</td>";
48
            $rez.="<td>".$st."</td><td>".$act."</td></tr>";
49
        }
50
        $rez.="</table>";
51
        echo $rez;
52
    }
53
 
54
    function ShowRequest($id){
55
        $query='SELECT * FROM `requests` WHERE id='.$id;
56
        $result=mysql_query($query);
57
        $data=mysql_fetch_array($result);
58
        if(empty($data['id'])){$rez="<div class='add'>Указанный запрос не найден!</div>";}
59
        else{
60
            $desk=$data['desk'];
61
            if(empty($desk)){$desk="&nbsp";}
62
            if($data['type']==0){$type="статья";}else{$type="файл";}
63
            $rez="<h2>Запрос №".$data['id']."</h2>";
64
            $rez.="<table>";
65
            $rez.="<tr><td>Название</td><td>".$data['name']."</td></tr>";
66
            $rez.="<tr><td>Тип</td><td>".$type."</td></tr>";
67
            $rez.="<tr><td>Описание</td><td>".$desk."</td></tr>";
68
            $rez.="<tr><td>Дата</td><td>".$data['date']."</td></tr>";
69
            $rez.="<tr><td>Автор</td><td>".$data['author']."</td></tr>";
70
            if($data['status']!=0){
71
                $rez.="<tr><td>Ссылка</td><td><a href='".$data['url']."'>".$data['url']."</a></td></tr>";
72
                $rez.="<tr><td>Комментарий</td><td>".$data['comment']."</td></tr>";
73
            }
74
            else{
75
                $rez.="<td colspan='2'><a href='index.php?act=make&id=".$id."'>Выполнить</a></td>";
76
            }
77
            $rez.="</table>";
78
        }
79
        $rez.="<div class='add'><a href='index.php'>Назад</a></div>";
80
        echo $rez;
81
    }
82
 
83
    function ShowAddForm(){
84
        $rez="<h2>Добавление запроса</h2>";
85
        $rez.="<form action='process.php' method='post'><table>";
86
        $rez.="<tr><td>* Название:</td><td><input type='text' size='40' name='name'></td></tr>";
87
        $rez.="<tr><td>Имя:</td><td><input type='text' size='40' name='author'></td></tr>";
88
        $rez.="<tr><td>* Тип:</td><td><input type='radio' name='type' value='file'>Файл<Br><input type='radio' checked name='type' value='article'>Статья</td></tr>";
89
        $rez.="<tr><td>Описание:</td><td><textarea name='desk' cols='40' rows='3'></textarea></td></tr>";
90
        $rez.="<tr><td colspan='2'><input type='submit' value='Добавить'><input type='hidden' name='act' value='add'></td></tr></table>";
91
        $rez.="<div style='text-align:center;font:normal 8pt sans;'>* Поля обязательные для заполнения</div>";
92
        echo $rez;
93
    }
94
 
95
    function AddRequest($name,$desk,$author,$type){
96
        if(empty($author)){$author='anonymous';}
97
        if(empty($name)){die("ОШИБКА: Не заполнено поле 'Название'!");}
98
        $sql = 'INSERT INTO `requests` (`id`, `name`, `desk`, `status`, `date`, `author`, `url`, `comment`, `type`) VALUES (NULL, \''.$name.'\', \''.$desk.'\', \'0\', NOW(), \''.$author.'\', \'\', \'\', \''.$type.'\');';
99
        $result=mysql_query($sql);
100
        return mysql_insert_id();
101
    }
102
 
103
    function MakeRequest($id,$url,$comment){
104
        if(empty($url)){die("ОШИБКА: Не заполнено поле 'URL'!");}
105
       /* $sql = 'SELECT `status` FROM `requests` WHERE id='.(int)$id;
106
        $result=mysql_query($sql);
107
        $status=mysql_fetch_field($result,'status');
108
        if($status==1){die("ОШИБКА: Текущий запрос уже выполнен!");}
109
        */$sql="UPDATE `requests` SET `status` = '1',`url` = '".$url."',`comment` = '".$comment."' WHERE `requests`.`id` =".$id." LIMIT 1 ;";
110
        $result=mysql_query($sql);
111
    }
112
 
113
    function ShowMakeForm($id){
114
        $rez="<h2>Выполнение запроса</h2>";
115
        $rez.="<form action='process.php' method='post'><table>";
116
        $rez.="<tr><td>* URL:</td><td><input type='text' size='40' name='name'></td></tr>";
117
        $rez.="<tr><td>Комментарий:</td><td><textarea name='desk' cols='40' rows='3'></textarea></td></tr>";
118
        $rez.="<tr><td colspan='2'><input type='submit' value='Выполнить'><input type='hidden' name='act' value='make'><input type='hidden' name='id' value='".$id."'></td></tr></table>";
119
        $rez.="<div style='text-align:center;font:normal 8pt sans;'>* Поля обязательные для заполнения</div>";
120
        echo $rez;
121
    }
122
}
123
?>