Mercurial > hg > fapweb
annotate admajax.php @ 690:bad79296eb34
Cleanups, rename variables.
author | Matti Hamalainen <ccr@tnsp.org> |
---|---|
date | Sun, 09 Nov 2014 21:17:40 +0200 |
parents | a934b2de8ef1 |
children | 45750a346f3e |
rev | line source |
---|---|
0 | 1 <? |
56 | 2 // |
571
ce11ea112a65
Change the header blurb a bit.
Matti Hamalainen <ccr@tnsp.org>
parents:
565
diff
changeset
|
3 // FAPWeb - Simple Web-based Demoparty Management System |
136
aeebfedb5709
Add some copyright headers.
Matti Hamalainen <ccr@tnsp.org>
parents:
133
diff
changeset
|
4 // Party administration page AJAX backend module |
565 | 5 // (C) Copyright 2012-2014 Tecnic Software productions (TNSP) |
56 | 6 // |
59
e5e38ed4e837
Work on compo entry addition and editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
57
diff
changeset
|
7 $sessionType = "admin"; |
175
8df523e6326a
User require_once instead of require.
Matti Hamalainen <ccr@tnsp.org>
parents:
169
diff
changeset
|
8 require_once "mconfig.inc.php"; |
8df523e6326a
User require_once instead of require.
Matti Hamalainen <ccr@tnsp.org>
parents:
169
diff
changeset
|
9 require_once "msite.inc.php"; |
8df523e6326a
User require_once instead of require.
Matti Hamalainen <ccr@tnsp.org>
parents:
169
diff
changeset
|
10 require_once "msession.inc.php"; |
0 | 11 |
214 | 12 |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
13 function stValidateRequestCompoData($full, $ctype) |
214 | 14 { |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
15 $res = TRUE; |
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
16 |
671
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
17 stChkRequestItemFail("name", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
18 array(CHK_ISGT, VT_STR, 0, "Compo name too short"), |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
19 array(CHK_LTEQ, VT_STR, SET_LEN_COMPO_NAME, "Compo name too long.")); |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
20 |
671
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
21 stChkRequestItemFail("description", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
22 array(CHK_ISGT, VT_STR, 10, "Compo description too short"), |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
23 array(CHK_LTEQ, VT_STR, SET_LEN_COMPO_DESC, "Compo description too long.")); |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
24 |
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
25 // Not a full check? |
214 | 26 if (!$full) |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
27 return $res; |
214 | 28 |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
29 // Check by compo type |
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
30 switch ($ctype) |
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
31 { |
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
32 case COMPO_NORMAL: |
671
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
33 stChkRequestItemFail("voting", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
34 array(CHK_TYPE, VT_BOOL, "Invalid data.")); |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
35 break; |
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
36 } |
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
37 |
671
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
38 stChkRequestItemFail("visible", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
39 array(CHK_TYPE, VT_BOOL, "Invalid data.")); |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
40 |
671
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
41 stChkRequestItemFail("show_authors", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
42 array(CHK_TYPE, VT_BOOL, "Invalid data.")); |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
43 |
671
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
44 stChkRequestItemFail("cpath", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
45 array(CHK_LTEQ, VT_STR, SET_LEN_COMPO_PATH, "Compo file path too long.")); |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
46 |
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
47 return $res; |
214 | 48 } |
49 | |
50 | |
228 | 51 function stValidateRequestEntryData(&$compo_id) |
214 | 52 { |
671
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
53 $res = TRUE; |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
54 |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
55 stChkRequestItemFail("name", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
56 array(CHK_ISGT, VT_STR, 0, "Entry name too short."), |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
57 array(CHK_LTEQ, VT_STR, SET_LEN_ENTRY_NAME, "Entry name too long.")); |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
58 |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
59 stChkRequestItemFail("author", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
60 array(CHK_ISGT, VT_STR, 0, "Author name not set."), |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
61 array(CHK_LTEQ, VT_STR, SET_LEN_ENTRY_AUTHOR, "Entry author too long.")); |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
62 |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
63 stChkRequestItemFail("filename", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
64 array(CHK_TYPE, VT_TEXT, "Invalid data."), |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
65 array(CHK_LTEQ, VT_STR, SET_LEN_ENTRY_FILENAME, "Entry filename too long.")); |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
66 |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
67 stChkRequestItemFail("info", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
68 array(CHK_TYPE, VT_TEXT, "Invalid data."), |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
69 array(CHK_LTEQ, VT_STR, SET_LEN_ENTRY_INFO, "Entry info too long.")); |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
70 |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
71 stChkRequestItemFail("compo_id", $compo_id, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
72 array(CHK_TYPE, VT_INT, "Invalid compo ID.")); |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
73 |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
74 return $res; |
214 | 75 } |
76 | |
77 | |
228 | 78 function stValidateRequestNewsData() |
214 | 79 { |
671
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
80 $res = TRUE; |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
81 |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
82 stChkRequestItemFail("text", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
83 array(CHK_ISGT, VT_STR, 0, "News text too short."), |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
84 array(CHK_LTEQ, VT_STR, SET_LEN_NEWS_TEXT, "News text too long.")); |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
85 |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
86 stChkRequestItemFail("author", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
87 array(CHK_ISGT, VT_STR, 0, "News author name too short."), |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
88 array(CHK_LTEQ, VT_STR, SET_LEN_NEWS_AUTHOR, "News author name too long.")); |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
89 |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
90 stChkRequestItemFail("title", $fake, $res, |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
91 array(CHK_ISGT, VT_STR, 0, "News title too short."), |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
92 array(CHK_LTEQ, VT_STR, SET_LEN_NEWS_TITLE, "News title too long.")); |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
93 |
11b6e5c7ba86
Use stChkRequestItemFail() where appropriate.
Matti Hamalainen <ccr@tnsp.org>
parents:
669
diff
changeset
|
94 return $res; |
214 | 95 } |
96 | |
97 | |
223
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
98 function stGetCompoData($id, $item, $prefix) |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
99 { |
644
de35a9743557
Implement changing of compo type.
Matti Hamalainen <ccr@tnsp.org>
parents:
643
diff
changeset
|
100 global $compoModeData; |
de35a9743557
Implement changing of compo type.
Matti Hamalainen <ccr@tnsp.org>
parents:
643
diff
changeset
|
101 |
de35a9743557
Implement changing of compo type.
Matti Hamalainen <ccr@tnsp.org>
parents:
643
diff
changeset
|
102 // XXX TODO Dropdown menu or so for selecting compo type |
640
c78e11aa3162
Rename a database field, so that it does not conflict with AJAX request item
Matti Hamalainen <ccr@tnsp.org>
parents:
636
diff
changeset
|
103 switch ($item["ctype"]) |
635
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
104 { |
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
105 case COMPO_NORMAL: |
641 | 106 $str = " ".stGetFormCheckBoxInput("voting", $id, $prefix, $item["voting"], |
107 "Enable voting", "onChange=\"setCompoData(".$id.",'voting')\""); | |
635
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
108 break; |
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
109 |
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
110 default: |
641 | 111 $str = " ".stGetFormHiddenInput("voting", $id, $prefix, $item["voting"]); |
635
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
112 break; |
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
113 } |
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
114 |
223
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
115 return |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
116 " <h2>#".$id." - ".chentities($item["name"])."</h2>\n". |
675 | 117 " Type: ".stGetFormOptionListFromArray("cotype".$id, " ", FALSE, $compoModeData, $item["ctype"], 0, "updateCompoType(".$id.")"). |
644
de35a9743557
Implement changing of compo type.
Matti Hamalainen <ccr@tnsp.org>
parents:
643
diff
changeset
|
118 " - ".$compoModeData[$item["ctype"]][1]."<br />\n". |
635
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
119 " Name: ".stGetFormTextInput(40, SET_LEN_COMPO_NAME, "name", $id, $prefix, $item["name"])."<br />\n". |
640
c78e11aa3162
Rename a database field, so that it does not conflict with AJAX request item
Matti Hamalainen <ccr@tnsp.org>
parents:
636
diff
changeset
|
120 " File path: ".stGetFormTextInput(40, SET_LEN_COMPO_PATH, "cpath", $id, $prefix, $item["cpath"])."<br />\n". |
635
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
121 " ".stGetFormTextArea(8, 60, "description", $id, $prefix, $item["description"])."<br />\n". |
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
122 " ".stGetFormButtonInput("update", $id, $prefix, "Update", "updateCompo(".$id.")")."\n". |
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
123 " ".stGetFormButtonInput("delete", $id, $prefix, "Delete", "deleteCompo(".$id.")")."\n". |
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
124 " ".stGetFormCheckBoxInput("visible", $id, $prefix, $item["visible"], "Visible", "onChange=\"setCompoData(".$id.",'visible')\"")."\n". |
59d14c0825cd
Somewhat fix compo data updating. Work is still needed to have the planned
Matti Hamalainen <ccr@tnsp.org>
parents:
634
diff
changeset
|
125 " ".stGetFormCheckBoxInput("show_authors", $id, $prefix, $item["show_authors"], "Show authors", "onChange=\"setCompoData(".$id.",'show_authors')\"")."\n". |
640
c78e11aa3162
Rename a database field, so that it does not conflict with AJAX request item
Matti Hamalainen <ccr@tnsp.org>
parents:
636
diff
changeset
|
126 $str."\n"; |
223
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
127 } |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
128 |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
129 |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
130 function stGetNewsItemData($id, $item, $prefix) |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
131 { |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
132 return |
227
44081a2066f5
Cosmetic improvements in news editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
223
diff
changeset
|
133 " <h2>".chentities($item["title"])."</h2>\n". |
223
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
134 " ".stGetFormTextInput(40, SET_LEN_NEWS_TITLE, "title", $id, $prefix, $item["title"]). |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
135 " - posted ".date("d M Y / H:i", $item["utime"])."<br />\n". |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
136 " ".stGetFormTextArea(5, 60, "text", $id, $prefix, $item["text"])."<br />\n". |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
137 " ".stGetFormTextInput(20, SET_LEN_NEWS_AUTHOR, "author", $id, $prefix, $item["author"])."\n". |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
138 " ".stGetFormButtonInput("", "upd".$id, $prefix, "Update", "updateNews(".$id.")")."\n". |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
139 " ".stGetFormButtonInput("", "del".$id, $prefix, "Delete", "deleteNews(".$id.")")."\n"; |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
140 } |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
141 |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
142 |
690
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
143 function stPrintEntryItemData($item, $row, $tr, $prefix, $ctype, $edit) |
257
ef9a007c0876
Modularize and add methods for getting single entry.
Matti Hamalainen <ccr@tnsp.org>
parents:
252
diff
changeset
|
144 { |
690
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
145 global $entryFlagsList; |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
146 |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
147 $eid = $item["id"]; |
682
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
148 if ($ctype === FALSE) |
690
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
149 $ctype = stFetchSQLColumn("SELECT ctype FROM compos WHERE id=".$item["compo_id"]); |
682
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
150 |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
151 if ($tr) |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
152 { |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
153 echo |
689
a934b2de8ef1
Add row classes to entry table elements.
Matti Hamalainen <ccr@tnsp.org>
parents:
687
diff
changeset
|
154 " <tr class=\"".($row % 2 == 1 ? "rodd" : "reven"). |
a934b2de8ef1
Add row classes to entry table elements.
Matti Hamalainen <ccr@tnsp.org>
parents:
687
diff
changeset
|
155 "\" id=\"entry".$eid."\" onClick=\"activateEntry(".$eid.")\">\n"; |
682
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
156 } |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
157 |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
158 echo |
690
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
159 " <td>".($item["show_id"] > 0 ? $item["show_id"] : "-")."</td>\n". |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
160 " ".stGetTDFormTextInput($edit, 20, SET_LEN_ENTRY_NAME, "name", $eid, $prefix, $item["name"])."\n". |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
161 " ".stGetTDFormTextInput($edit, 15, SET_LEN_ENTRY_AUTHOR, "author", $eid, $prefix, $item["author"])."\n"; |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
162 |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
163 echo |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
164 " ".stGetTDFormTextInput($edit, 20, SET_LEN_ENTRY_FILENAME, "filename", $eid, $prefix, $item["filename"])."\n"; |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
165 |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
166 echo |
257
ef9a007c0876
Modularize and add methods for getting single entry.
Matti Hamalainen <ccr@tnsp.org>
parents:
252
diff
changeset
|
167 " <td>". |
690
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
168 stGetFormTextArea(2, 30, "info", $eid, $prefix, $item["info"])."<br />". |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
169 stGetFormTextArea(2, 30, "notes", $eid, $prefix, $item["notes"])."<br />". |
682
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
170 // XXX TODO flags? |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
171 "</td>\n". |
690
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
172 " <td>". |
257
ef9a007c0876
Modularize and add methods for getting single entry.
Matti Hamalainen <ccr@tnsp.org>
parents:
252
diff
changeset
|
173 "</td>\n"; |
682
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
174 |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
175 if ($edit) |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
176 { |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
177 echo |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
178 " <td>". |
690
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
179 stGetFormButtonInput("delete", $eid, $prefix, "Del", "deleteEntry(".$item["compo_id"].",".$eid.")"). |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
180 stGetFormTextInput(3, 3, "compo_id", $eid, $prefix, $item["compo_id"]). |
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
181 stGetFormButtonInput("update", $eid, $prefix, "Upd", "updateEntry(".$item["compo_id"].",".$eid.")"). |
682
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
182 "</td>\n"; |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
183 } |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
184 |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
185 if ($tr) |
2e54b6858ce9
A tiny bit more work on entry editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
681
diff
changeset
|
186 echo " </tr>\n"; |
257
ef9a007c0876
Modularize and add methods for getting single entry.
Matti Hamalainen <ccr@tnsp.org>
parents:
252
diff
changeset
|
187 } |
ef9a007c0876
Modularize and add methods for getting single entry.
Matti Hamalainen <ccr@tnsp.org>
parents:
252
diff
changeset
|
188 |
ef9a007c0876
Modularize and add methods for getting single entry.
Matti Hamalainen <ccr@tnsp.org>
parents:
252
diff
changeset
|
189 |
321
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
190 function stGetVoteKeyClass($item) |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
191 { |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
192 global $voteKeyMode; |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
193 |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
194 switch ($voteKeyMode) |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
195 { |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
196 case VOTE_FREELY: |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
197 $cond = 0; |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
198 break; |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
199 |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
200 case VOTE_ACTIVATE: |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
201 $cond = $item["active"]; |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
202 break; |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
203 |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
204 case VOTE_ASSIGN: |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
205 $cond = $item["key_id"] > 0; |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
206 break; |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
207 } |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
208 |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
209 return "votekey ".($cond ? "vkeyActive" : "vkeyInactive"); |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
210 } |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
211 |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
212 |
312 | 213 function stGetVoteKeyItemData($id, $item, $prefix) |
214 { | |
215 global $voteKeyMode, $voteKeyLen; | |
216 | |
217 switch ($voteKeyMode) | |
218 { | |
219 case VOTE_FREELY: | |
220 case VOTE_ACTIVATE: | |
668
2943ec592cc1
Validate votekey length - set vote key length when printing padding.
Matti Hamalainen <ccr@tnsp.org>
parents:
666
diff
changeset
|
221 $klen = $voteKeyLen - strlen($item["key"]); |
312 | 222 $str = sprintf( |
223 "<span class=\"keyid\">%03d</span> : ". | |
224 "<span class=\"keycode\">%s</span>", | |
225 $id, | |
668
2943ec592cc1
Validate votekey length - set vote key length when printing padding.
Matti Hamalainen <ccr@tnsp.org>
parents:
666
diff
changeset
|
226 (($klen > 0) ? str_repeat(" ", $klen) : "").$item["key"]); |
312 | 227 |
228 if ($voteKeyMode == VOTE_ACTIVATE) | |
229 { | |
319
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
230 $str .= stGetFormCheckBoxInput("active", $id, $prefix, $item["active"], FALSE, |
534
067bef3846aa
Use onChange instead of onClick.
Matti Hamalainen <ccr@tnsp.org>
parents:
519
diff
changeset
|
231 "class=\"keyactive\" onChange=\"voteKeySetActive(".$id.")\"", ""); |
312 | 232 } |
233 | |
234 return $str; | |
235 | |
236 case VOTE_ASSIGN: | |
319
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
237 $str = |
312 | 238 " <td class=\"name\">".chentities($item["name"])."</td>\n". |
239 " <td class=\"groups\">".chentities($item["groups"])."</td>\n". | |
240 " <td class=\"vkeynum\">". | |
241 stGetFormTextInput(5, 5, "key_id", $id, $prefix, $item["key_id"]). | |
319
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
242 stGetFormButtonInput("assign", $id, $prefix, "Set", "voteKeyAssign(".$id.",1)"); |
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
243 |
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
244 if ($item["key_id"] != 0) |
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
245 $str .= stGetFormButtonInput("clear", $id, $prefix, "Clear", "voteKeyAssign(".$id.",0)"); |
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
246 |
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
247 $str .= |
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
248 "</td>\n". |
324
f3dfdb4fb221
Improve vkey admin visual usability.
Matti Hamalainen <ccr@tnsp.org>
parents:
321
diff
changeset
|
249 " <td class=\"vkey\">"; |
312 | 250 |
324
f3dfdb4fb221
Improve vkey admin visual usability.
Matti Hamalainen <ccr@tnsp.org>
parents:
321
diff
changeset
|
251 if ($item["key_id"] > 0) |
f3dfdb4fb221
Improve vkey admin visual usability.
Matti Hamalainen <ccr@tnsp.org>
parents:
321
diff
changeset
|
252 $str .= sprintf("<span class=\"keyid\">%03d</span>". |
f3dfdb4fb221
Improve vkey admin visual usability.
Matti Hamalainen <ccr@tnsp.org>
parents:
321
diff
changeset
|
253 " : <span class=\"keycode\">%s</span>", |
f3dfdb4fb221
Improve vkey admin visual usability.
Matti Hamalainen <ccr@tnsp.org>
parents:
321
diff
changeset
|
254 $item["key_id"], chentities($item["key"])); |
f3dfdb4fb221
Improve vkey admin visual usability.
Matti Hamalainen <ccr@tnsp.org>
parents:
321
diff
changeset
|
255 |
f3dfdb4fb221
Improve vkey admin visual usability.
Matti Hamalainen <ccr@tnsp.org>
parents:
321
diff
changeset
|
256 $str .= "</td>\n"; |
319
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
257 return $str; |
312 | 258 } |
259 } | |
260 | |
261 | |
398 | 262 function stGetInfoOneEntryData($show_id, $compo_id) |
263 { | |
411
2aa58de08d6d
If show_id for entry is 0, ignore it.
Matti Hamalainen <ccr@tnsp.org>
parents:
407
diff
changeset
|
264 if ($show_id > 0) |
2aa58de08d6d
If show_id for entry is 0, ignore it.
Matti Hamalainen <ccr@tnsp.org>
parents:
407
diff
changeset
|
265 { |
2aa58de08d6d
If show_id for entry is 0, ignore it.
Matti Hamalainen <ccr@tnsp.org>
parents:
407
diff
changeset
|
266 $sql = stPrepareSQL("SELECT * FROM entries WHERE show_id=%d AND compo_id=%d", |
2aa58de08d6d
If show_id for entry is 0, ignore it.
Matti Hamalainen <ccr@tnsp.org>
parents:
407
diff
changeset
|
267 $show_id, $compo_id); |
398 | 268 |
411
2aa58de08d6d
If show_id for entry is 0, ignore it.
Matti Hamalainen <ccr@tnsp.org>
parents:
407
diff
changeset
|
269 if (($entry = stFetchSQL($sql)) !== false) |
468
bc1755a9f89f
Add filenames to be shown in current/prev entry in compo control.
Matti Hamalainen <ccr@tnsp.org>
parents:
467
diff
changeset
|
270 { |
bc1755a9f89f
Add filenames to be shown in current/prev entry in compo control.
Matti Hamalainen <ccr@tnsp.org>
parents:
467
diff
changeset
|
271 return |
bc1755a9f89f
Add filenames to be shown in current/prev entry in compo control.
Matti Hamalainen <ccr@tnsp.org>
parents:
467
diff
changeset
|
272 "<b>#".$entry["show_id"]." - ".chentities($entry["name"]). |
bc1755a9f89f
Add filenames to be shown in current/prev entry in compo control.
Matti Hamalainen <ccr@tnsp.org>
parents:
467
diff
changeset
|
273 " by ".chentities($entry["author"])."</b><br />". |
470 | 274 "<i>".chentities(substr($entry["filename"], 0, 40))."</i>"; |
468
bc1755a9f89f
Add filenames to be shown in current/prev entry in compo control.
Matti Hamalainen <ccr@tnsp.org>
parents:
467
diff
changeset
|
275 } |
411
2aa58de08d6d
If show_id for entry is 0, ignore it.
Matti Hamalainen <ccr@tnsp.org>
parents:
407
diff
changeset
|
276 } |
2aa58de08d6d
If show_id for entry is 0, ignore it.
Matti Hamalainen <ccr@tnsp.org>
parents:
407
diff
changeset
|
277 return "-"; |
398 | 278 } |
279 | |
280 | |
417 | 281 function stGetInfoCurrEntryData($indent) |
398 | 282 { |
283 $compoID = stGetDisplayVar("compoID"); | |
284 if ($compoID > 0) | |
285 { | |
286 $sql = stPrepareSQL("SELECT * FROM compos WHERE id=%d", $compoID); | |
287 if (($entry = stFetchSQL($sql)) !== false) | |
288 $strCompo = $entry["id"]." - ".chentities($entry["name"]); | |
289 | |
290 $strCurrEntry = stGetInfoOneEntryData(stGetDisplayVar("compoCurrEntry"), $compoID); | |
291 $strPrevEntry = stGetInfoOneEntryData(stGetDisplayVar("compoPrevEntry"), $compoID); | |
292 } | |
293 else | |
468
bc1755a9f89f
Add filenames to be shown in current/prev entry in compo control.
Matti Hamalainen <ccr@tnsp.org>
parents:
467
diff
changeset
|
294 $strCompo = $strCurrEntry = $strCurrEntryFile = $strPrevEntry = "-"; |
398 | 295 |
296 return | |
470 | 297 $indent."<div><b>".$strCompo."</b></div>\n". |
468
bc1755a9f89f
Add filenames to be shown in current/prev entry in compo control.
Matti Hamalainen <ccr@tnsp.org>
parents:
467
diff
changeset
|
298 $indent."<div>Current entry:<br />".$strCurrEntry."</div>\n". |
bc1755a9f89f
Add filenames to be shown in current/prev entry in compo control.
Matti Hamalainen <ccr@tnsp.org>
parents:
467
diff
changeset
|
299 $indent."<div>Previous entry:<br />".$strPrevEntry."</div>\n"; |
398 | 300 } |
301 | |
302 | |
417 | 303 function stGetInfoCurrEntryList($indent, $outer) |
398 | 304 { |
404 | 305 $sql = stPrepareSQL( |
306 "SELECT * FROM entries WHERE compo_id=%d ORDER BY show_id ASC", | |
307 stGetDisplayVar("compoID")); | |
308 | |
309 $currShowID = stGetDisplayVar("compoCurrEntry"); | |
413
9eb46567f0aa
If shown entry ID is undefined, don't select anything.
Matti Hamalainen <ccr@tnsp.org>
parents:
412
diff
changeset
|
310 if ($currShowID <= 0) |
9eb46567f0aa
If shown entry ID is undefined, don't select anything.
Matti Hamalainen <ccr@tnsp.org>
parents:
412
diff
changeset
|
311 $currShowID = -1; |
9eb46567f0aa
If shown entry ID is undefined, don't select anything.
Matti Hamalainen <ccr@tnsp.org>
parents:
412
diff
changeset
|
312 |
675 | 313 $str = stGetFormOptionListStart("ctrlEntryList", $indent, $outer); |
407 | 314 |
404 | 315 if (($res = stExecSQL($sql)) !== false) |
316 { | |
317 foreach ($res as $item) | |
318 { | |
417 | 319 $str .= $indent." ". |
675 | 320 stGetFormOptionListItem($item["show_id"], |
404 | 321 ($item["show_id"] == $currShowID), |
469 | 322 sprintf("%3d. %-25s by %-15s", |
323 $item["show_id"], | |
324 substr($item["name"], 0, 25), | |
325 substr($item["author"], 0, 15))); | |
404 | 326 } |
327 } | |
417 | 328 |
675 | 329 return $str.stGetFormOptionListEnd($indent, $outer); |
417 | 330 } |
331 | |
332 | |
333 function stGetInfoRotationLists($indent, $outer) | |
334 { | |
335 $sql = | |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
336 "SELECT rot_list_data.*, ". |
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
337 "(SELECT COUNT(*) FROM rot_list_slides WHERE list_id=rot_list_data.id) AS nslides ". |
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
338 "FROM rot_list_data ". |
417 | 339 "ORDER BY id DESC"; |
340 | |
675 | 341 $str = stGetFormOptionListStart("ctrlRotationLists", $indent, $outer); |
453 | 342 $currListID = stGetDisplayVar("rotateList"); |
417 | 343 |
344 if (($res = stExecSQL($sql)) !== false) | |
345 { | |
346 foreach ($res as $item) | |
347 { | |
348 $str .= $indent." ". | |
675 | 349 stGetFormOptionListItem($item["id"], |
417 | 350 ($currListID == $item["id"]), |
351 $item["name"]." (".$item["nslides"]." slides)"); | |
352 } | |
353 } | |
354 | |
675 | 355 return $str.stGetFormOptionListEnd($indent, $outer); |
398 | 356 } |
357 | |
358 | |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
359 function stGetInfoDisplaySlides($indent, $outer) |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
360 { |
675 | 361 $str = stGetFormOptionListStart("ctrlDisplaySlides", $indent, $outer); |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
362 |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
363 $sql = "SELECT * FROM display_slides ORDER BY id DESC"; |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
364 if (($res = stExecSQL($sql)) !== false) |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
365 { |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
366 foreach ($res as $item) |
675 | 367 $str .= $indent." ".stGetFormOptionListItem($item["id"], FALSE, $item["title"]); |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
368 } |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
369 |
675 | 370 return $str.stGetFormOptionListEnd($indent, $outer); |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
371 } |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
372 |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
373 |
423 | 374 function stGetInfoRotationListEditFull($indent, $outer, $list_id) |
375 { | |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
376 $sql = stPrepareSQL("SELECT * FROM rot_list_data WHERE id=%d", $list_id); |
449 | 377 if (($data = stFetchSQL($sql)) === false) |
657
abfbacdff90a
Add error message for missing rotation list IDs.
Matti Hamalainen <ccr@tnsp.org>
parents:
655
diff
changeset
|
378 return "<p>No such rotation list ID #".intval($list_id)."</p>"; |
449 | 379 |
423 | 380 $str = |
381 ($outer ? $indent."<div class=\"ctrlBox\" id=\"ctrlRotationListEdit\">\n" : ""). | |
382 $indent." <div class=\"ctrlTitle\">Edit rotation list</div>\n". | |
453 | 383 $indent." ".stGetFormTextInput(30, SET_LEN_ROT_LIST_NAME, "", "ctrlEDRotationListName", "", $data["name"])."\n". |
384 $indent." ".stGetFormButtonInput("updname", "", "", "Save", "updateRotationList(".$list_id.")")."\n". | |
450 | 385 "<div>Available slides:</div>\n". |
675 | 386 stGetFormOptionListStart("ctrlEDDisplaySlides", $indent." ", TRUE); |
423 | 387 |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
388 $sql = "SELECT * FROM display_slides"; |
423 | 389 if (($res = stExecSQL($sql)) !== false) |
390 { | |
391 foreach ($res as $item) | |
675 | 392 $str .= $indent." ".stGetFormOptionListItem($item["id"], FALSE, $item["title"]); |
423 | 393 } |
394 | |
395 $str .= | |
675 | 396 stGetFormOptionListEnd($indent." ", TRUE). |
450 | 397 "<div>List content:</div>\n". |
423 | 398 stGetInfoRotationListEditData($indent." ", TRUE, $list_id). |
399 $indent." <div class=\"ctrlButtons\">\n". | |
464 | 400 // $indent." ".stGetFormButtonInput("moveslideup", "", "", "Move Up", "moveRotationListSlide(".$list_id.", -1)")."\n". |
401 // $indent." ".stGetFormButtonInput("moveslidedn", "", "", "Move Down", "moveRotationListSlide(".$list_id.", 1)")."\n". | |
453 | 402 $indent." ".stGetFormButtonInput("addslide", "", "", "Add slide", "addRotationListSlide(".$list_id.")")."\n". |
403 $indent." ".stGetFormButtonInput("delslide", "", "", "Remove slide", "removeRotationListSlide(".$list_id.")")."\n". | |
450 | 404 $indent." ".stGetFormButtonInput("closeedit", "", "", "Close", "jsCloseAdminPopup()")."\n". |
423 | 405 $indent." </div>\n". |
406 ($outer ? $indent."</div>\n" : ""); | |
407 | |
408 return $str; | |
409 } | |
410 | |
411 | |
412 function stGetInfoRotationListEditData($indent, $outer, $list_id) | |
413 { | |
414 $sql = stPrepareSQL( | |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
415 "SELECT display_slides.*,rot_list_slides.order_num FROM display_slides ". |
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
416 "LEFT JOIN rot_list_slides ON display_slides.id=rot_list_slides.slide_id ". |
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
417 "WHERE rot_list_slides.list_id=%d ". |
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
418 "ORDER BY rot_list_slides.order_num DESC", |
423 | 419 $list_id); |
420 | |
675 | 421 $str = stGetFormOptionListStart("ctrlEDRotationList", $indent, $outer); |
423 | 422 |
423 if (($res = stExecSQL($sql)) !== false) | |
424 { | |
425 foreach ($res as $item) | |
449 | 426 { |
461 | 427 $str .= $indent." ". |
675 | 428 stGetFormOptionListItem($item["id"]."_".$item["order_num"], FALSE, $item["title"]); |
449 | 429 } |
423 | 430 } |
431 | |
675 | 432 return $str.stGetFormOptionListEnd($indent, $outer); |
423 | 433 } |
434 | |
435 | |
455 | 436 function stGetInfoActiveRotationList($indent, $outer) |
437 { | |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
438 $sql = stPrepareSQL("SELECT * FROM rot_list_data WHERE id=%d", |
455 | 439 stGetDisplayVar("rotateList")); |
440 | |
441 $str = $indent.($outer ? "<div id=\"ctrlActiveRotationList\">" : ""). | |
442 "<b>Active list:</b> "; | |
443 | |
444 if (($slist = stFetchSQL($sql)) === false) | |
445 $str .= "-"; | |
446 else | |
466 | 447 $str .= chentities(substr($slist["name"], 0, 40)); |
455 | 448 |
449 return $str.($outer ? "</div>\n" : ""); | |
450 } | |
451 | |
452 | |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
453 function stGetInfoDisplaySlideEdit($indent, $outer, $slide_id) |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
454 { |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
455 $prefix = "ctrlDisplaySlide"; |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
456 |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
457 $str = |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
458 ($outer ? "<div class=\"ctrlBox\" id=\"".$prefix."Edit\">\n" : ""). |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
459 $indent." <form method=\"post\" action=\"\" onsubmit=\"return updateDisplaySlide(".$slide_id.")\">\n". |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
460 $indent." <div class=\"ctrlTitle\">Edit display slide</div>\n"; |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
461 |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
462 $sql = stPrepareSQL("SELECT * FROM display_slides WHERE id=%d", $slide_id); |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
463 if (($slide = stFetchSQL($sql)) !== false) |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
464 { |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
465 $str .= |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
466 " ".stGetFormTextInput(40, SET_LEN_DISP_SLIDE_TITLE, "", "Title", $prefix, $slide["title"])."<br />\n". |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
467 " ".stGetFormTextArea(5, 40, "", "Text", $prefix, $slide["text"])."<br />\n"; |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
468 } |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
469 |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
470 $str .= |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
471 " <div class=\"ctrlButtons\">\n". |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
472 " ".stGetFormSubmitInput("createslide", "Save slide")."\n". |
442
dfe1e94d6f17
Make close/cancel button bigger.
Matti Hamalainen <ccr@tnsp.org>
parents:
441
diff
changeset
|
473 " ".stGetFormButtonInput("cancelslide", "", "", "Close / Cancel", "jsCloseAdminPopup()")."\n". |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
474 " </div>\n". |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
475 " </form>\n". |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
476 ($outer ? "</div>\n" : ""); |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
477 |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
478 return $str; |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
479 } |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
480 |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
481 |
214 | 482 function stGetSaveButton() |
483 { | |
484 return "<input type=\"submit\" value=\" Save \" />\n"; | |
485 } | |
486 | |
487 | |
374 | 488 function stGetShowModeButton($mode, $name, $cmode) |
489 { | |
396 | 490 return |
491 "<input type=\"radio\" id=\"showMode".$mode. | |
492 "\" name=\"showMode\" value=\"".$mode."\" ". | |
534
067bef3846aa
Use onChange instead of onClick.
Matti Hamalainen <ccr@tnsp.org>
parents:
519
diff
changeset
|
493 "onChange=\"setShowMode(".$mode.")\" ". |
396 | 494 ($cmode == $mode ? "checked=\"checked\" ": "")."/>". |
495 "<label for=\"showMode".$mode."\">".chentities($name)."</label>"; | |
374 | 496 } |
497 | |
498 | |
373 | 499 function stRandomizeCompoShowOrder($compo_id, $patch) |
500 { | |
501 $entries = stExecSQL("SELECT id,show_id FROM entries WHERE compo_id=".$compo_id); | |
371 | 502 if ($entries !== FALSE) |
503 { | |
376
55007fe09371
And some more work on the backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
375
diff
changeset
|
504 $ncount = stFetchSQLColumn("SELECT COUNT(*) FROM entries WHERE compo_id=".$compo_id." AND show_id<>0"); |
371 | 505 $final = array(); |
373 | 506 |
376
55007fe09371
And some more work on the backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
375
diff
changeset
|
507 if ($patch && $ncount > 0) |
373 | 508 { |
376
55007fe09371
And some more work on the backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
375
diff
changeset
|
509 $index = -1; |
373 | 510 foreach ($entries as $entry) |
511 { | |
512 if ($entry["show_id"] == 0) | |
513 $final[] = $entry["id"]; | |
372 | 514 |
373 | 515 if ($entry["show_id"] > $index) |
516 $index = $entry["show_id"]; | |
517 } | |
376
55007fe09371
And some more work on the backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
375
diff
changeset
|
518 |
373 | 519 $index++; |
520 } | |
521 else | |
522 { | |
523 foreach ($entries as $entry) | |
524 $final[] = $entry["id"]; | |
372 | 525 |
373 | 526 shuffle($final); |
527 $index = 1; | |
528 } | |
529 | |
371 | 530 foreach ($final as $entry) |
531 { | |
532 $sql = stPrepareSQL("UPDATE entries SET show_id=%d WHERE id=%d", $index, $entry); | |
533 if (stExecSQL($sql) === false) | |
534 { | |
535 stError("Error updating entry show positions."); | |
536 break; | |
537 } | |
538 $index++; | |
539 } | |
540 } | |
541 } | |
542 | |
543 | |
214 | 544 // |
0 | 545 // Check if we are allowed to execute |
214 | 546 // |
687
a38eab6f2bd2
Improve session expiration handling.
Matti Hamalainen <ccr@tnsp.org>
parents:
686
diff
changeset
|
547 if (!stCheckHTTPS() || !stAdmSessionAuth(TRUE) || !stCSRFCheck()) |
0 | 548 { |
686
8730bffcffd4
Add new return code 903 and handling for it.
Matti Hamalainen <ccr@tnsp.org>
parents:
682
diff
changeset
|
549 stSetStatus(903, "Session expired."); |
59
e5e38ed4e837
Work on compo entry addition and editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
57
diff
changeset
|
550 stSetupCacheControl(); |
686
8730bffcffd4
Add new return code 903 and handling for it.
Matti Hamalainen <ccr@tnsp.org>
parents:
682
diff
changeset
|
551 stDumpAJAXStatusErrors(); |
59
e5e38ed4e837
Work on compo entry addition and editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
57
diff
changeset
|
552 |
e5e38ed4e837
Work on compo entry addition and editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
57
diff
changeset
|
553 stSessionEnd(SESS_ADMIN); |
e5e38ed4e837
Work on compo entry addition and editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
57
diff
changeset
|
554 |
613
6fc379f4033d
Session expiration handling made different.
Matti Hamalainen <ccr@tnsp.org>
parents:
609
diff
changeset
|
555 echo |
6fc379f4033d
Session expiration handling made different.
Matti Hamalainen <ccr@tnsp.org>
parents:
609
diff
changeset
|
556 "<h1>Session expired</h1>". |
6fc379f4033d
Session expiration handling made different.
Matti Hamalainen <ccr@tnsp.org>
parents:
609
diff
changeset
|
557 "<div><a href=\"admin.php\">Click here to relogin</a>.</div>\n"; |
6fc379f4033d
Session expiration handling made different.
Matti Hamalainen <ccr@tnsp.org>
parents:
609
diff
changeset
|
558 |
0 | 559 exit; |
560 } | |
561 | |
214 | 562 |
563 // | |
564 // Initialize | |
565 // | |
544 | 566 ob_start(); |
567 | |
8
4c5f651aa107
Migrate certain settings to SQL database, cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
5
diff
changeset
|
568 stSetupCacheControl(); |
0 | 569 |
570 if (!stConnectSQLDB()) | |
571 die("Could not connect to SQL database."); | |
572 | |
8
4c5f651aa107
Migrate certain settings to SQL database, cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
5
diff
changeset
|
573 stReloadSettings(); |
378 | 574 stReloadDisplayVars(); |
687
a38eab6f2bd2
Improve session expiration handling.
Matti Hamalainen <ccr@tnsp.org>
parents:
686
diff
changeset
|
575 stSessionExpire(SESS_ADMIN, FALSE); |
8
4c5f651aa107
Migrate certain settings to SQL database, cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
5
diff
changeset
|
576 |
0 | 577 |
305
b96c41bd9dd6
More work on admin backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
302
diff
changeset
|
578 $voteKeyMode = stGetSetting("voteKeyMode"); |
312 | 579 $voteKeyLen = stGetSetting("userKeyLength"); |
208
8985d2bdb29b
More work on error handling etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
207
diff
changeset
|
580 $type = stGetRequestItem("type", ""); |
8985d2bdb29b
More work on error handling etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
207
diff
changeset
|
581 switch (stGetRequestItem("action", "")) |
0 | 582 { |
370
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
583 case "randomize": |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
584 // |
370
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
585 // Randomize entries display order |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
586 // |
373 | 587 $patch = intval(stGetRequestItem("patch", 1)); |
371 | 588 if ($type == "all") |
0 | 589 { |
371 | 590 if (($compos = stExecSQL("SELECT id FROM compos")) === FALSE) |
370
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
591 stError("Eh? SQL error occured."); |
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
592 else |
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
593 foreach ($compos as $compo) |
373 | 594 stRandomizeCompoShowOrder($compo["id"], $patch); |
371 | 595 } |
596 else | |
597 if ($type == "compo") | |
598 { | |
599 if (stChkRequestItem("id", $compo_id, array(CHK_TYPE, VT_INT, "Invalid data."))) | |
373 | 600 stRandomizeCompoShowOrder($compo_id, $patch); |
370
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
601 } |
375 | 602 break; |
603 | |
604 case "check": | |
605 // | |
606 // Perform systems check | |
607 // | |
377
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
608 $errors = 0; |
375 | 609 echo |
610 "<h1>Competitions / voting</h1>\n". | |
611 "<ul>\n"; | |
612 | |
613 echo "<li>".(stGetSetting("allowVoting") ? "Voting <b>IS ENABLED</b>." : "Voting is NOT enabled!")."</li>\n"; | |
614 | |
615 if (($compos = stExecSQL("SELECT * FROM compos")) === FALSE) | |
616 stError("Eh? SQL error occured."); | |
370
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
617 else |
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
618 { |
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
619 foreach ($compos as $compo) |
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
620 { |
373 | 621 $nentries = stFetchSQLColumn("SELECT COUNT(*) FROM entries WHERE show_id=0 AND compo_id=".$compo["id"]); |
370
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
622 if ($nentries > 0) |
377
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
623 { |
375 | 624 echo "<li>Compo <b>#".$compo["id"]." - ".$compo["name"]."</b> has NO show order set for some entries.</li>\n"; |
377
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
625 $errors++; |
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
626 } |
370
d65f28bf1080
Add backend code for generating entry show positions.
Matti Hamalainen <ccr@tnsp.org>
parents:
366
diff
changeset
|
627 } |
0 | 628 } |
377
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
629 |
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
630 $nenabled = stFetchSQLColumn("SELECT COUNT(*) FROM compos WHERE visible<>0 AND voting<>0"); |
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
631 if ($nenabled == 0) |
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
632 echo "<li>No competitions that are visible and enabled for voting.</li>\n"; |
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
633 |
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
634 $nenabled = stFetchSQLColumn("SELECT COUNT(*) FROM compos WHERE visible=0 AND voting<>0"); |
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
635 if ($nenabled > 0) |
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
636 echo "<li>".$nenabled." competitions that are NOT visible, but are enabled for voting?</li>\n"; |
381 | 637 |
638 $entries = stFetchSQL("SELECT COUNT(*) AS nentries, COUNT(DISTINCT compo_id) AS ncompos FROM entries"); | |
639 if ($entries !== FALSE) | |
640 echo "<li><b>".$entries["nentries"]."</b> compo entries in system in <b>".$entries["ncompos"]."</b> compos.</li>\n"; | |
377
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
641 |
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
642 if ($errors == 0) |
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
643 echo "<li>No errors/warnings detected.</li>\n"; |
f7b53225d315
Add some more sanity checking.
Matti Hamalainen <ccr@tnsp.org>
parents:
376
diff
changeset
|
644 |
375 | 645 echo "</ul>\n"; |
646 | |
0 | 647 break; |
648 | |
390
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
649 case "ctrl": |
392 | 650 // |
651 // Party information system control | |
652 // | |
390
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
653 switch ($type) |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
654 { |
450 | 655 case "setRotateDuration": |
656 if (stChkRequestItem("duration", $duration, | |
657 array(CHK_TYPE, VT_INT, "Invalid data."), | |
658 array(CHK_RANGE, VT_INT, array(5, 60), "Invalid slide time value, must be 5 - 60 seconds."))) | |
659 { | |
454 | 660 stSetDisplayVarUpd("rotateDuration", $duration); |
661 } | |
662 break; | |
663 | |
455 | 664 case "setActiveRotationList": |
454 | 665 if (stChkRequestItem("id", $list_id, array(CHK_TYPE, VT_INT, "Invalid data."))) |
666 { | |
667 stSetDisplayVarUpd("rotateList", $list_id); | |
450 | 668 } |
669 break; | |
670 | |
390
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
671 case "setShowMode": |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
672 if (stChkRequestItem("mode", $mode, |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
673 array(CHK_TYPE, VT_INT, "Invalid data."), |
391 | 674 array(CHK_RANGE, VT_INT, array(SMODE_DISABLED, SMODE_COMPO), "Invalid mode value."))) |
390
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
675 { |
454 | 676 stSetDisplayVarUpd("showMode", $mode); |
390
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
677 } |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
678 break; |
450 | 679 |
390
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
680 case "setCompoID": |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
681 if (stChkRequestItem("id", $compo_id, array(CHK_TYPE, VT_INT, "Invalid data."))) |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
682 { |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
683 if (stFetchSQL("SELECT id FROM compos WHERE id=".$compo_id) === false) |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
684 stError("Invalid compo ID ".$compo_id); |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
685 else |
395 | 686 { |
546
f1f55db4228f
Always update current info display compo id if requested.
Matti Hamalainen <ccr@tnsp.org>
parents:
545
diff
changeset
|
687 stSetDisplayVarUpd("compoID", $compo_id); |
454 | 688 stSetDisplayVar("compoCurrEntry", 0); |
689 stSetDisplayVar("compoPrevEntry", 0); | |
395 | 690 } |
390
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
691 } |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
692 break; |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
693 |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
694 case "setEntry": |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
695 case "nextEntry": |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
696 case "prevEntry": |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
697 if (($compo_id = stGetDisplayVar("compoID")) > 0) |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
698 { |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
699 $prev = $curr = stGetDisplayVar("compoCurrEntry"); |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
700 $nentries = stFetchSQLColumn("SELECT COUNT(*) FROM entries WHERE compo_id=".$compo_id); |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
701 switch ($type) |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
702 { |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
703 case "setEntry": |
669 | 704 if (stChkRequestItem("index", $tmp, |
705 array(CHK_TYPE, VT_INT, "Invalid index."))) | |
390
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
706 $curr = $tmp; |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
707 break; |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
708 |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
709 case "nextEntry": |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
710 if ($curr < $nentries) |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
711 $curr++; |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
712 break; |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
713 |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
714 case "prevEntry": |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
715 if ($curr > 1) |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
716 $curr--; |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
717 break; |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
718 } |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
719 |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
720 if (!$errorSet) |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
721 { |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
722 stSetDisplayVar("compoCurrEntry", $curr); |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
723 stSetDisplayVar("compoPrevEntry", $prev); |
407 | 724 stDisplayUpdated(); |
390
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
725 } |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
726 } |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
727 else |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
728 stError("No valid competition set."); |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
729 break; |
421 | 730 |
731 case "setTempSlide": | |
429 | 732 if (stChkRequestItem("id", $slide_id, array(CHK_TYPE, VT_INT, "Invalid data.")) && |
733 stChkRequestItem("duration", $slide_dur, array(CHK_RANGE, VT_INT, array(1, 60), "Invalid duration range, should be 1-60 min."))) | |
734 { | |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
735 $sql = stPrepareSQL("SELECT * FROM display_slides WHERE id=%d", $slide_id); |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
736 if (($slide = stFetchSQL($sql)) !== false) |
429 | 737 { |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
738 stSetDisplayVar("tempDuration", $slide_dur); |
429 | 739 stSetDisplayVar("tempSlide", $slide["id"]); |
740 stSetDisplayVar("tempSlideSet", TRUE); | |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
741 echo "Temporary slide '".chentities($slide["title"])."' set for <b>".$slide_dur."</b> minutes."; |
441 | 742 stDisplayUpdated(); |
429 | 743 } |
744 else | |
745 stError("No such slide ID #".$slide_id); | |
746 } | |
421 | 747 break; |
748 | |
472 | 749 case "skipToNextSlide": |
750 if (stGetDisplayVar("activeSlideMode") == SMODE_ROTATE) | |
751 { | |
752 stSetDisplayVar("activeSlideExpire", 0); | |
753 stDisplayUpdated(); | |
754 } | |
755 break; | |
756 | |
457
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
757 case "copyDisplaySlide": |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
758 if (stChkRequestItem("id", $slide_id, array(CHK_TYPE, VT_INT, "Invalid data."))) |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
759 { |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
760 $sql = stPrepareSQL("SELECT * FROM display_slides WHERE id=%d", $slide_id); |
457
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
761 if (($slide = stFetchSQL($sql)) !== false) |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
762 { |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
763 $sql = stPrepareSQL("INSERT INTO display_slides (title,text) VALUES (%s,%s)", |
457
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
764 $slide["title"]." (copy)", $slide["text"]); |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
765 |
548
b3e9c3eedc23
Use the helper functions for insertion.
Matti Hamalainen <ccr@tnsp.org>
parents:
546
diff
changeset
|
766 if (($new_id = stExecSQLInsert($sql)) !== false) |
457
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
767 echo stGetInfoDisplaySlideEdit("", TRUE, $new_id); |
548
b3e9c3eedc23
Use the helper functions for insertion.
Matti Hamalainen <ccr@tnsp.org>
parents:
546
diff
changeset
|
768 else |
b3e9c3eedc23
Use the helper functions for insertion.
Matti Hamalainen <ccr@tnsp.org>
parents:
546
diff
changeset
|
769 stError("Could not insert slide."); |
457
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
770 } |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
771 else |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
772 stError("No such slide ID #".$slide_id); |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
773 } |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
774 break; |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
775 |
433 | 776 case "newDisplaySlide": |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
777 $sql = stPrepareSQL("INSERT INTO display_slides (title) VALUES (%s)", "New slide"); |
548
b3e9c3eedc23
Use the helper functions for insertion.
Matti Hamalainen <ccr@tnsp.org>
parents:
546
diff
changeset
|
778 if (($slide_id = stExecSQLInsert($sql)) !== false) |
434 | 779 echo stGetInfoDisplaySlideEdit("", TRUE, $slide_id); |
421 | 780 break; |
781 | |
433 | 782 case "updateDisplaySlide": |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
783 if (stChkRequestItem("id", $slide_id, array(CHK_TYPE, VT_INT, "Invalid data.")) && |
451 | 784 stChkRequestItem("title", $fake, |
785 array(CHK_GTEQ, VT_STR, 1, "Slide title too short."), | |
786 array(CHK_LTEQ, VT_STR, SET_LEN_DISP_SLIDE_TITLE, "Slide title too long.") | |
787 ) && | |
788 stChkRequestItem("text", $fake, | |
789 array(CHK_LTEQ, VT_STR, SET_LEN_DISP_SLIDE_TEXT, "Slide content too long.") | |
790 )) | |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
791 { |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
792 $sql = stPrepareSQLUpdate("display_slides", |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
793 "WHERE id=".$slide_id, |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
794 array( |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
795 "title" => "S", |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
796 "text" => "S", |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
797 )); |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
798 |
548
b3e9c3eedc23
Use the helper functions for insertion.
Matti Hamalainen <ccr@tnsp.org>
parents:
546
diff
changeset
|
799 if (stExecSQL($sql) !== false) |
b3e9c3eedc23
Use the helper functions for insertion.
Matti Hamalainen <ccr@tnsp.org>
parents:
546
diff
changeset
|
800 { |
b3e9c3eedc23
Use the helper functions for insertion.
Matti Hamalainen <ccr@tnsp.org>
parents:
546
diff
changeset
|
801 stSetStatus(200, "Slide updated."); |
b3e9c3eedc23
Use the helper functions for insertion.
Matti Hamalainen <ccr@tnsp.org>
parents:
546
diff
changeset
|
802 stDisplayUpdated(); |
b3e9c3eedc23
Use the helper functions for insertion.
Matti Hamalainen <ccr@tnsp.org>
parents:
546
diff
changeset
|
803 } |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
804 } |
421 | 805 break; |
806 | |
433 | 807 case "deleteDisplaySlide": |
421 | 808 if (stChkRequestItem("id", $slide_id, array(CHK_TYPE, VT_INT, "Invalid data."))) |
809 { | |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
810 $sql = stPrepareSQL("DELETE FROM display_slides WHERE id=%d", $slide_id); |
421 | 811 stExecSQLCond($sql, "Slide deleted."); |
812 | |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
813 $sql = stPrepareSQL("DELETE FROM rot_list_slides WHERE slide_id=%d", $slide_id); |
421 | 814 stExecSQLCond($sql, "Slide list refs deleted."); |
441 | 815 stDisplayUpdated(); |
421 | 816 } |
817 break; | |
818 | |
422 | 819 case "newRotationList": |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
820 $sql = stPrepareSQL("INSERT INTO rot_list_data (name) VALUES (%s)", "New list #"); |
548
b3e9c3eedc23
Use the helper functions for insertion.
Matti Hamalainen <ccr@tnsp.org>
parents:
546
diff
changeset
|
821 if (($list_id = stExecSQLInsert($sql)) !== false) |
427 | 822 { |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
823 $sql = stPrepareSQL("UPDATE rot_list_data SET name=%s WHERE id=%d", |
431 | 824 "New list #".$list_id, $list_id); |
427 | 825 |
826 if (stExecSQLCond($sql, "OK!") !== false) | |
827 echo stGetInfoRotationListEditFull("", TRUE, $list_id); | |
828 } | |
422 | 829 break; |
830 | |
831 case "updateRotationList": | |
453 | 832 if (stChkRequestItem("id", $list_id, array(CHK_TYPE, VT_INT, "Invalid data.")) && |
833 stChkRequestItem("name", $fake, | |
834 array(CHK_GTEQ, VT_STR, 3, "Rotation list name too short."), | |
835 array(CHK_LTEQ, VT_STR, SET_LEN_ROT_LIST_NAME, "Rotation list name too long."))) | |
836 { | |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
837 $sql = stPrepareSQLUpdate("rot_list_data", |
453 | 838 "WHERE id=".$list_id, |
839 array( | |
840 "name" => "S", | |
841 )); | |
842 | |
843 stExecSQLCond($sql, "OK, list updated."); | |
844 stDisplayUpdated(); | |
845 } | |
441 | 846 stDisplayUpdated(); |
421 | 847 break; |
848 | |
422 | 849 case "deleteRotationList": |
850 if (stChkRequestItem("id", $list_id, array(CHK_TYPE, VT_INT, "Invalid data."))) | |
851 { | |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
852 $sql = stPrepareSQL("DELETE FROM rot_list_data WHERE id=%d", $list_id); |
422 | 853 stExecSQLCond($sql, "List data deleted."); |
854 | |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
855 $sql = stPrepareSQL("DELETE FROM rot_list_slides WHERE list_id=%d", $list_id); |
422 | 856 stExecSQLCond($sql, "List slide refs deleted."); |
441 | 857 stDisplayUpdated(); |
422 | 858 } |
421 | 859 break; |
860 | |
422 | 861 case "moveRotationListSlide": |
421 | 862 if (stChkRequestItem("list_id", $list_id, array(CHK_TYPE, VT_INT, "Invalid data.")) && |
863 stChkRequestItem("slide_id", $slide_id, array(CHK_TYPE, VT_INT, "Invalid data.")) && | |
461 | 864 stChkRequestItem("order_num", $order_num, array(CHK_TYPE, VT_INT, "Invalid data.")) && |
421 | 865 stChkRequestItem("dir", $dir, array(CHK_TYPE, VT_INT, "Invalid data."))) |
866 { | |
867 } | |
868 break; | |
869 | |
422 | 870 case "addRotationListSlide": |
421 | 871 if (stChkRequestItem("list_id", $list_id, array(CHK_TYPE, VT_INT, "Invalid data.")) && |
872 stChkRequestItem("slide_id", $slide_id, array(CHK_TYPE, VT_INT, "Invalid data."))) | |
873 { | |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
874 $nslides = stFetchSQLColumn(stPrepareSQL("SELECT COUNT(*) FROM rot_list_slides WHERE list_id=%d", $list_id)); |
459 | 875 $sql = stPrepareSQL( |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
876 "INSERT INTO rot_list_slides (list_id,slide_id,order_num) VALUES (%d,%d,%d)", |
421 | 877 $list_id, $slide_id, $nslides+1); |
878 | |
459 | 879 if (stExecSQLCond($sql, "Slide added to list.")) |
880 { | |
881 stNormalizeListSlideOrder($list_id); | |
882 stDisplayUpdated(); | |
883 } | |
421 | 884 } |
885 break; | |
886 | |
450 | 887 case "removeRotationListSlide": |
421 | 888 if (stChkRequestItem("list_id", $list_id, array(CHK_TYPE, VT_INT, "Invalid data.")) && |
461 | 889 stChkRequestItem("slide_id", $slide_id, array(CHK_TYPE, VT_INT, "Invalid data.")) && |
890 stChkRequestItem("order_num", $order_num, array(CHK_TYPE, VT_INT, "Invalid data."))) | |
421 | 891 { |
542
8c1a53532be0
Rename various database tables and column names for better SQL compatibility.
Matti Hamalainen <ccr@tnsp.org>
parents:
534
diff
changeset
|
892 $sql = stPrepareSQL("DELETE FROM rot_list_slides WHERE list_id=%d AND slide_id=%d AND order_num=%d", |
461 | 893 $list_id, $slide_id, $order_num); |
459 | 894 |
895 if (stExecSQLCond($sql, "List slide refs deleted.")) | |
896 { | |
897 stNormalizeListSlideOrder($list_id); | |
898 stDisplayUpdated(); | |
899 } | |
421 | 900 } |
901 break; | |
390
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
902 } |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
903 break; |
3257ae94ba1c
Work on show display backend logic.
Matti Hamalainen <ccr@tnsp.org>
parents:
385
diff
changeset
|
904 |
0 | 905 case "get": |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
906 // |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
907 // Get specific data |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
908 // |
0 | 909 switch ($type) |
910 { | |
398 | 911 case "infoCurrEntryData": |
417 | 912 echo stGetInfoCurrEntryData("", FALSE); |
398 | 913 break; |
404 | 914 |
915 case "infoCurrEntryList": | |
417 | 916 echo stGetInfoCurrEntryList("", FALSE); |
917 break; | |
918 | |
919 case "infoRotationLists": | |
920 echo stGetInfoRotationLists("", FALSE); | |
404 | 921 break; |
398 | 922 |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
923 case "infoDisplaySlides": |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
924 echo stGetInfoDisplaySlides("", FALSE); |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
925 break; |
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
926 |
422 | 927 case "infoRotationListEdit": |
427 | 928 if (stChkRequestItem("id", $list_id, array(CHK_TYPE, VT_INT, "Invalid data."))) |
459 | 929 echo stGetInfoRotationListEditFull("", stGetRequestItem("full", TRUE), $list_id); |
423 | 930 break; |
398 | 931 |
423 | 932 case "infoRotationListEditData": |
427 | 933 if (stChkRequestItem("id", $list_id, array(CHK_TYPE, VT_INT, "Invalid data."))) |
934 echo stGetInfoRotationListEditData("", FALSE, $list_id); | |
393 | 935 break; |
936 | |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
937 case "infoDisplaySlideEdit": |
421 | 938 if (stChkRequestItem("id", $slide_id, array(CHK_TYPE, VT_INT, "Invalid data."))) |
467
9e987c975dca
Default to full html of the slide edit.
Matti Hamalainen <ccr@tnsp.org>
parents:
466
diff
changeset
|
939 echo stGetInfoDisplaySlideEdit("", TRUE, $slide_id); |
393 | 940 break; |
941 | |
455 | 942 case "infoActiveRotationList": |
943 echo stGetInfoActiveRotationList("", FALSE); | |
944 break; | |
945 | |
419 | 946 case "infoMain": |
449 | 947 // |
948 // Main information control screen | |
949 // | |
378 | 950 $showMode = stGetDisplayVar("showMode"); |
951 echo | |
396 | 952 "<div id=\"ctrlModeControls\">\n". |
378 | 953 "Active mode:\n". |
391 | 954 stGetShowModeButton(SMODE_DISABLED, "Off/disabled", $showMode)."\n". |
378 | 955 stGetShowModeButton(SMODE_ROTATE, "Slide rotation", $showMode)."\n". |
956 stGetShowModeButton(SMODE_COMPO, "Compo mode", $showMode)."\n". | |
418
0688a1d2122e
Add link for opening the info view window.
Matti Hamalainen <ccr@tnsp.org>
parents:
417
diff
changeset
|
957 "<a href=\"show.php\" target=\"_blank\">Open info window</a>\n". |
512
998a09b332f1
Add plain text printable results visible for admins.
Matti Hamalainen <ccr@tnsp.org>
parents:
480
diff
changeset
|
958 "<a href=\"print.php?type=results\" target=\"_blank\">Printable results list</a>\n". |
392 | 959 "</div>\n". |
396 | 960 "<div id=\"ctrlSystemControls\">\n". |
961 stGetFormButtonInput("syscheck", "", "", "Perform system check", "performSystemCheck()")."\n". | |
476 | 962 stGetFormButtonInput("generate", "", "", "Add missing show positions", "generateEntryPositions(0, 1)")."\n". |
396 | 963 stGetFormButtonInput("regenerate", "", "", "ReGenerate ALL show positions", "generateEntryPositions(0, 0)")."\n". |
378 | 964 "</div>\n"; |
393 | 965 |
966 echo | |
967 "<div class=\"ctrlBox\" id=\"ctrlListRotationLists\">\n". | |
968 " <div class=\"ctrlTitle\">Rotation lists:</div>\n". | |
450 | 969 " <div class=\"ctrlInfo\">Lists of slides, that are shown for X seconds and 'rotated' to next one.</div>\n". |
417 | 970 stGetInfoRotationLists(" ", TRUE). |
393 | 971 " <div class=\"ctrlButtons\">\n". |
450 | 972 " ".stGetFormButtonInput("setdur", "", "", "Set", "setRotateDuration()")."\n". |
973 " ".stGetFormTextInput(3, 5, "", "ctrlRotSlideDuration", "", stGetDisplayVar("rotateDuration"))." sec\n". | |
974 " - ". | |
454 | 975 " ".stGetFormButtonInput("actlist", "", "", "Set Active", "setActiveRotationList()")."\n". |
416
876846d8ed5b
Rename some database things.
Matti Hamalainen <ccr@tnsp.org>
parents:
415
diff
changeset
|
976 " ".stGetFormButtonInput("editlist", "", "", "Edit", "editRotationList()")."\n". |
393 | 977 " ".stGetFormButtonInput("newlist", "", "", "New", "newRotationList()")."\n". |
978 " ".stGetFormButtonInput("dellist", "", "", "Delete", "deleteRotationList()")."\n". | |
979 " </div>\n". | |
455 | 980 stGetInfoActiveRotationList(" ", TRUE). |
393 | 981 "</div>\n"; |
982 | |
983 echo | |
984 "<div class=\"ctrlBox\" id=\"ctrlListDisplaySlides\">\n". | |
985 "<div class=\"ctrlTitle\">Display slides:</div>\n". | |
443
2a4d5ded6c79
Add helpful information popups.
Matti Hamalainen <ccr@tnsp.org>
parents:
442
diff
changeset
|
986 " <div class=\"ctrlInfo\">Editable slides (think 'powerpoint') for information/announcements. ". |
2a4d5ded6c79
Add helpful information popups.
Matti Hamalainen <ccr@tnsp.org>
parents:
442
diff
changeset
|
987 "Can be collected into slide rotations or set to display as 'temp slide' at any given time.</div>\n". |
438
48903fd966cd
Things are starting to work.
Matti Hamalainen <ccr@tnsp.org>
parents:
437
diff
changeset
|
988 stGetInfoDisplaySlides(" ", TRUE). |
393 | 989 " <div class=\"ctrlButtons\">\n". |
457
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
990 " ".stGetFormButtonInput("editslide", "", "", "Edit", "editDisplaySlide()")."\n". |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
991 " ".stGetFormButtonInput("copyslide", "", "", "Copy", "copyDisplaySlide()")."\n". |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
992 " ".stGetFormButtonInput("newslide", "", "", "New", "newDisplaySlide()")."\n". |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
993 " ".stGetFormButtonInput("delslide", "", "", "Delete", "deleteDisplaySlide()")."\n". |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
994 " </div>\n". |
3b5184c6b36f
Add slide copying function.
Matti Hamalainen <ccr@tnsp.org>
parents:
455
diff
changeset
|
995 " <div class=\"ctrlButtons\">\n". |
429 | 996 " ".stGetFormTextInput(3, 5, "", "ctrlTempSlideDuration", "", stGetDisplayVar("tempDuration"))." min\n". |
393 | 997 " ".stGetFormButtonInput("setslide", "", "", "Set Temp", "activateTempSlide()")."\n". |
472 | 998 " ".stGetFormButtonInput("nextslide", "", "", "Skip to next", "skipToNextSlide()")."\n". |
393 | 999 " </div>\n". |
427 | 1000 "</div>\n". |
393 | 1001 "<div class=\"ctrlBox\" id=\"ctrlCompoControl\">\n". |
398 | 1002 " <div class=\"ctrlTitle\">Competition control:</div>\n". |
443
2a4d5ded6c79
Add helpful information popups.
Matti Hamalainen <ccr@tnsp.org>
parents:
442
diff
changeset
|
1003 " <div class=\"ctrlInfo\">Controls for competition showing mode. Select and activate desired compo, then ". |
2a4d5ded6c79
Add helpful information popups.
Matti Hamalainen <ccr@tnsp.org>
parents:
442
diff
changeset
|
1004 "hit 'Next entry' to activate the first entry to show. <b>Notice! You need to have generated 'show positions' ". |
2a4d5ded6c79
Add helpful information popups.
Matti Hamalainen <ccr@tnsp.org>
parents:
442
diff
changeset
|
1005 "before starting compos!</b></div>\n". |
398 | 1006 " <div class=\"ctrlDBox1\">\n". |
675 | 1007 stGetFormOptionListStart("ctrlCompoList", " ", TRUE); |
398 | 1008 |
1009 $sql = | |
1010 "SELECT compos.*, ". | |
545
d5ac0521ca16
Possibly fix a query to work with Postgresql.
Matti Hamalainen <ccr@tnsp.org>
parents:
544
diff
changeset
|
1011 "COUNT(DISTINCT entries.id) AS nentries ". |
d5ac0521ca16
Possibly fix a query to work with Postgresql.
Matti Hamalainen <ccr@tnsp.org>
parents:
544
diff
changeset
|
1012 "FROM compos LEFT JOIN entries ON compos.id=entries.compo_id ". |
644
de35a9743557
Implement changing of compo type.
Matti Hamalainen <ccr@tnsp.org>
parents:
643
diff
changeset
|
1013 "GROUP BY compos.id ". |
de35a9743557
Implement changing of compo type.
Matti Hamalainen <ccr@tnsp.org>
parents:
643
diff
changeset
|
1014 "HAVING COUNT(DISTINCT entries.id) > 0 AND compos.ctype=".COMPO_NORMAL." ". |
de35a9743557
Implement changing of compo type.
Matti Hamalainen <ccr@tnsp.org>
parents:
643
diff
changeset
|
1015 "ORDER BY compos.id DESC"; |
398 | 1016 |
1017 $currCompoID = stGetDisplayVar("compoID"); | |
1018 if (($res = stExecSQL($sql)) !== false) | |
1019 { | |
1020 foreach ($res as $item) | |
1021 { | |
675 | 1022 echo " ".stGetFormOptionListItem($item["id"], |
398 | 1023 ($item["id"] == $currCompoID), |
469 | 1024 sprintf("%-20s (%d entries)", substr($item["name"], 0, 20), $item["nentries"])); |
398 | 1025 } |
1026 } | |
1027 | |
1028 echo | |
675 | 1029 stGetFormOptionListEnd(" ", TRUE). |
407 | 1030 " <div class=\"ctrlButtons\">\n". |
1031 " ".stGetFormButtonInput("setcompo", "", "", "Change compo", "activateCompo()")."\n". | |
1032 " </div>\n". | |
427 | 1033 " </div>\n". |
407 | 1034 " <div class=\"ctrlDBox1\">\n". |
417 | 1035 stGetInfoCurrEntryList(" ", TRUE). |
407 | 1036 " <div class=\"ctrlButtons\">\n". |
1037 " ".stGetFormButtonInput("setentry", "", "", "Set selected entry", "setSelectedEntry()")."\n". | |
1038 " ".stGetFormButtonInput("preventry", "", "", "Prev entry", "switchEntry(-1)")."\n". | |
1039 " ".stGetFormButtonInput("nextentry", "", "", "Next entry", "switchEntry(1)")."\n". | |
1040 " </div>\n". | |
393 | 1041 " </div>\n". |
407 | 1042 " <div class=\"ctrlDBox2\" id=\"ctrlCurrEntryData\">\n". |
417 | 1043 stGetInfoCurrEntryData(" "). |
407 | 1044 " </div>\n". |
424
8258b5ddcd7f
Temporarily comment out stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
423
diff
changeset
|
1045 "</div>\n"; |
427 | 1046 stGetInfoRotationListEditFull("", TRUE, 0); |
378 | 1047 break; |
1048 | |
0 | 1049 case "news": |
265 | 1050 echo |
1051 "<form method=\"post\" action=\"\" onsubmit=\"return addNews()\">\n". | |
1052 " ".stGetFormTextInput(40, SET_LEN_NEWS_TITLE, "", "nntitle", "", "")."<br />\n". | |
1053 " ".stGetFormTextArea(5, 60, "", "nntext", "", "")."<br />\n". | |
1054 " ".stGetFormTextInput(20, SET_LEN_NEWS_AUTHOR, "", "nnauthor", "", "orgaz")."\n". | |
1055 " ".stGetFormSubmitInput("nnadd", "Add post")."\n". | |
1056 " ".stGetFormButtonInput("", "", "", "Clear", "this.form.reset()")."\n". | |
1057 "</form>\n". | |
1058 "<hr />\n"; | |
1059 | |
0 | 1060 $sql = "SELECT * FROM news ORDER BY utime DESC"; |
265 | 1061 foreach (stExecSQL($sql) as $item) |
1062 { | |
1063 echo | |
1064 "<div id=\"news".$item["id"]."\">\n". | |
1065 stGetNewsItemData($item["id"], $item, "ne"). | |
634 | 1066 "</div>\n"; |
265 | 1067 } |
0 | 1068 break; |
1069 | |
223
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1070 case "newsitem": |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1071 $res = stFetchSQL(stPrepareSQL("SELECT * FROM news WHERE id=%D", "id")); |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1072 if ($res !== FALSE) |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1073 echo stGetNewsItemData($res["id"], $res, "ne"); |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1074 break; |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1075 |
0 | 1076 case "attendees": |
272
cd3283333ec1
Add link for printing out email addresses of participants.
Matti Hamalainen <ccr@tnsp.org>
parents:
270
diff
changeset
|
1077 echo |
273
39c247babc0c
Make the print links look a bit nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
272
diff
changeset
|
1078 "<div class=\"tabHeadersSub\">\n". |
275 | 1079 "<a href=\"print.php?type=emails\" target=\"_blank\">Show plain list of e-mails</a>\n". |
272
cd3283333ec1
Add link for printing out email addresses of participants.
Matti Hamalainen <ccr@tnsp.org>
parents:
270
diff
changeset
|
1080 "</div>\n"; |
cd3283333ec1
Add link for printing out email addresses of participants.
Matti Hamalainen <ccr@tnsp.org>
parents:
270
diff
changeset
|
1081 |
265 | 1082 // For adding a new one |
1083 $prefix = "ne"; | |
1084 echo | |
1085 "<table>\n". | |
1086 " <tr>\n". | |
1087 " <th>Name</th>\n". | |
1088 " <th>Groups</th>\n". | |
1089 " <th>Oneliner</th>\n". | |
1090 " <th>E-mail</th>\n". | |
1091 " <th>Actions</th>\n". | |
1092 " </tr>\n". | |
1093 " <tr>\n". | |
1094 " <td>".stGetFormTextInput(20, SET_LEN_USERNAME, "name", "x", $prefix, "")."</td>\n". | |
1095 " <td>".stGetFormTextInput(20, SET_LEN_GROUPS, "groups", "x", $prefix, "")."</td>\n". | |
1096 " <td>".stGetFormTextInput(30, SET_LEN_ONELINER, "oneliner", "x", $prefix, "")."</td>\n". | |
1097 " <td>".stGetFormTextInput(20, SET_LEN_EMAIL, "email", "x", $prefix, "")."</td>\n". | |
1098 " <td>".stGetFormButtonInput("add", "", $prefix, " Add new ", "addAttendee()")."</td>\n". | |
1099 " </tr>\n". | |
1100 "</table>\n". | |
1101 "<hr />\n"; | |
1102 | |
1103 // List of attendees | |
1104 echo | |
1105 "<table class=\"attendees\">\n". | |
1106 " <tr>\n". | |
1107 " <th class=\"name\">Name</th>\n". | |
1108 " <th class=\"groups\">Groups</th>\n". | |
1109 " <th class=\"regtime\">Registered</th>\n". | |
1110 " <th class=\"oneliner\">Oneliner</th>\n". | |
1111 " <th class=\"email\">E-mail</th>\n". | |
1112 " <th>Actions</th>\n". | |
1113 " </tr>\n"; | |
1114 | |
0 | 1115 $sql = "SELECT * FROM attendees ORDER BY regtime DESC"; |
265 | 1116 $row = 0; |
1117 foreach (stExecSQL($sql) as $item) | |
1118 stPrintAttendee($item, $row++, TRUE, TRUE, FALSE); | |
1119 | |
1120 echo | |
1121 "</table>\n"; | |
0 | 1122 break; |
1123 | |
205
77d33161f8be
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
204
diff
changeset
|
1124 case "attendee": |
77d33161f8be
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
204
diff
changeset
|
1125 $res = stFetchSQL(stPrepareSQL("SELECT * FROM attendees WHERE id=%D", "id")); |
77d33161f8be
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
204
diff
changeset
|
1126 if ($res !== FALSE) |
77d33161f8be
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
204
diff
changeset
|
1127 stPrintAttendee($res, -1, FALSE, TRUE, stGetRequestItem("edit", FALSE)); |
681 | 1128 else |
1129 stError("No such attendee ID!"); | |
205
77d33161f8be
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
204
diff
changeset
|
1130 break; |
77d33161f8be
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
204
diff
changeset
|
1131 |
312 | 1132 case "votekey": |
321
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
1133 case "votekeyclass": |
312 | 1134 switch ($voteKeyMode) |
1135 { | |
1136 case VOTE_FREELY: | |
1137 case VOTE_ACTIVATE: | |
1138 $sql = stPrepareSQL("SELECT * FROM votekeys WHERE id=%D", "id"); | |
1139 break; | |
1140 | |
1141 case VOTE_ASSIGN: | |
1142 $sql = stPrepareSQL("SELECT votekeys.key,attendees.* FROM attendees ". | |
1143 "LEFT JOIN votekeys ON votekeys.id=attendees.key_id ". | |
1144 "WHERE attendees.id=%D", "id"); | |
1145 break; | |
1146 } | |
1147 if (($res = stFetchSQL($sql)) !== FALSE) | |
321
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
1148 { |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
1149 if ($type == "votekeyclass") |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
1150 echo stGetVoteKeyClass($res); |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
1151 else |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
1152 echo stGetVoteKeyItemData($res["id"], $res, "vk"); |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
1153 } |
312 | 1154 break; |
1155 | |
105
a85f258f6beb
Move some things around and modularize the code.
Matti Hamalainen <ccr@tnsp.org>
parents:
90
diff
changeset
|
1156 case "voters": |
270
589b44acb74a
More work on votekey admin.
Matti Hamalainen <ccr@tnsp.org>
parents:
269
diff
changeset
|
1157 // Generate vote keys, if needed |
589b44acb74a
More work on votekey admin.
Matti Hamalainen <ccr@tnsp.org>
parents:
269
diff
changeset
|
1158 $numVKeys = stFetchSQLColumn("SELECT COUNT(*) FROM votekeys"); |
478
8dde27202989
And fix the previous commit ..
Matti Hamalainen <ccr@tnsp.org>
parents:
477
diff
changeset
|
1159 $numUsers = stFetchSQLColumn("SELECT COUNT(*) FROM attendees"); |
8dde27202989
And fix the previous commit ..
Matti Hamalainen <ccr@tnsp.org>
parents:
477
diff
changeset
|
1160 if (($tmp = stGetSetting("maxAttendeesHard")) > $numUsers) |
8dde27202989
And fix the previous commit ..
Matti Hamalainen <ccr@tnsp.org>
parents:
477
diff
changeset
|
1161 $numUsers = $tmp; |
8dde27202989
And fix the previous commit ..
Matti Hamalainen <ccr@tnsp.org>
parents:
477
diff
changeset
|
1162 else |
8dde27202989
And fix the previous commit ..
Matti Hamalainen <ccr@tnsp.org>
parents:
477
diff
changeset
|
1163 if (($tmp = stGetSetting("maxAttendeesSoft")) > $numUsers) |
8dde27202989
And fix the previous commit ..
Matti Hamalainen <ccr@tnsp.org>
parents:
477
diff
changeset
|
1164 $numUsers = $tmp; |
8dde27202989
And fix the previous commit ..
Matti Hamalainen <ccr@tnsp.org>
parents:
477
diff
changeset
|
1165 |
480
26033a4b754a
Oops, fix a silly off-by-one in votekey generation (1 less than wanted keys
Matti Hamalainen <ccr@tnsp.org>
parents:
478
diff
changeset
|
1166 while ($numVKeys <= $numUsers) |
270
589b44acb74a
More work on votekey admin.
Matti Hamalainen <ccr@tnsp.org>
parents:
269
diff
changeset
|
1167 { |
589b44acb74a
More work on votekey admin.
Matti Hamalainen <ccr@tnsp.org>
parents:
269
diff
changeset
|
1168 if (($key = stGenerateUserKey()) !== false) |
589b44acb74a
More work on votekey admin.
Matti Hamalainen <ccr@tnsp.org>
parents:
269
diff
changeset
|
1169 { |
589b44acb74a
More work on votekey admin.
Matti Hamalainen <ccr@tnsp.org>
parents:
269
diff
changeset
|
1170 if (stExecSQL(stPrepareSQL("INSERT INTO votekeys (key) VALUES (%s)", $key)) !== false) |
589b44acb74a
More work on votekey admin.
Matti Hamalainen <ccr@tnsp.org>
parents:
269
diff
changeset
|
1171 $numVKeys++; |
589b44acb74a
More work on votekey admin.
Matti Hamalainen <ccr@tnsp.org>
parents:
269
diff
changeset
|
1172 } |
589b44acb74a
More work on votekey admin.
Matti Hamalainen <ccr@tnsp.org>
parents:
269
diff
changeset
|
1173 } |
589b44acb74a
More work on votekey admin.
Matti Hamalainen <ccr@tnsp.org>
parents:
269
diff
changeset
|
1174 |
269
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1175 // List of votekeys |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1176 echo |
597
6de22c51c49b
Add warning about unconfigured voting mode.
Matti Hamalainen <ccr@tnsp.org>
parents:
571
diff
changeset
|
1177 "<div class=\"info\"><b>Voting mode: "; |
6de22c51c49b
Add warning about unconfigured voting mode.
Matti Hamalainen <ccr@tnsp.org>
parents:
571
diff
changeset
|
1178 |
6de22c51c49b
Add warning about unconfigured voting mode.
Matti Hamalainen <ccr@tnsp.org>
parents:
571
diff
changeset
|
1179 if (isset($voteModeData[$voteKeyMode])) |
6de22c51c49b
Add warning about unconfigured voting mode.
Matti Hamalainen <ccr@tnsp.org>
parents:
571
diff
changeset
|
1180 echo $voteModeData[$voteKeyMode][0]."</b>. ".$voteModeData[$voteKeyMode][1]; |
6de22c51c49b
Add warning about unconfigured voting mode.
Matti Hamalainen <ccr@tnsp.org>
parents:
571
diff
changeset
|
1181 else |
6de22c51c49b
Add warning about unconfigured voting mode.
Matti Hamalainen <ccr@tnsp.org>
parents:
571
diff
changeset
|
1182 echo "VOTE MODE NOT SET! CHECK CONFIGURATION!</b>"; |
6de22c51c49b
Add warning about unconfigured voting mode.
Matti Hamalainen <ccr@tnsp.org>
parents:
571
diff
changeset
|
1183 |
6de22c51c49b
Add warning about unconfigured voting mode.
Matti Hamalainen <ccr@tnsp.org>
parents:
571
diff
changeset
|
1184 echo |
6de22c51c49b
Add warning about unconfigured voting mode.
Matti Hamalainen <ccr@tnsp.org>
parents:
571
diff
changeset
|
1185 "</div>\n". |
273
39c247babc0c
Make the print links look a bit nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
272
diff
changeset
|
1186 "<div class=\"tabHeadersSub\">\n". |
275 | 1187 "<a href=\"print.php?type=votekeys\" target=\"_blank\">Show printable key list</a>\n". |
269
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1188 "</div>\n"; |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1189 |
305
b96c41bd9dd6
More work on admin backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
302
diff
changeset
|
1190 switch ($voteKeyMode) |
116
a95facb41c86
Some preliminary work on the votekey administration backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
113
diff
changeset
|
1191 { |
a95facb41c86
Some preliminary work on the votekey administration backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
113
diff
changeset
|
1192 case VOTE_FREELY: |
269
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1193 case VOTE_ACTIVATE: |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1194 $sql = "SELECT * FROM votekeys ORDER BY votekeys.id ASC"; |
116
a95facb41c86
Some preliminary work on the votekey administration backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
113
diff
changeset
|
1195 |
269
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1196 foreach (stExecSQL($sql) as $item) |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1197 { |
312 | 1198 echo |
321
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
1199 "<div class=\"".stGetVoteKeyClass($item). |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
1200 "\" id=\"vkey".$item["id"]."\">". |
312 | 1201 stGetVoteKeyItemData($item["id"], $item, "vk"). |
320 | 1202 "</div>\n"; |
269
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1203 } |
116
a95facb41c86
Some preliminary work on the votekey administration backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
113
diff
changeset
|
1204 break; |
a95facb41c86
Some preliminary work on the votekey administration backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
113
diff
changeset
|
1205 |
a95facb41c86
Some preliminary work on the votekey administration backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
113
diff
changeset
|
1206 case VOTE_ASSIGN: |
308
3cfd95758377
A bit of work on vote key management backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
305
diff
changeset
|
1207 $sql = "SELECT votekeys.key,attendees.* FROM attendees ". |
3cfd95758377
A bit of work on vote key management backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
305
diff
changeset
|
1208 "LEFT JOIN votekeys ON votekeys.id=attendees.key_id ". |
3cfd95758377
A bit of work on vote key management backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
305
diff
changeset
|
1209 "ORDER BY attendees.regtime DESC"; |
269
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1210 |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1211 echo |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1212 "<table class=\"attendees\">\n". |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1213 " <tr>\n". |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1214 " <th class=\"name\">Name</th>\n". |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1215 " <th class=\"groups\">Groups</th>\n". |
308
3cfd95758377
A bit of work on vote key management backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
305
diff
changeset
|
1216 " <th class=\"vkeynum\">Key #</th>\n". |
3cfd95758377
A bit of work on vote key management backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
305
diff
changeset
|
1217 " <th class=\"vkey\">Votekey</th>\n". |
269
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1218 " </tr>\n"; |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1219 |
312 | 1220 $index = 0; |
269
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1221 foreach (stExecSQL($sql) as $item) |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1222 { |
308
3cfd95758377
A bit of work on vote key management backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
305
diff
changeset
|
1223 echo |
321
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
1224 " <tr class=\"".stGetVoteKeyClass($item). |
9462a59d3ab3
Votekey activation usability improvements.
Matti Hamalainen <ccr@tnsp.org>
parents:
320
diff
changeset
|
1225 "\" id=\"vkey".$item["id"]."\">\n". |
312 | 1226 stGetVoteKeyItemData($item["id"], $item, "vk"). |
308
3cfd95758377
A bit of work on vote key management backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
305
diff
changeset
|
1227 " </tr>\n"; |
269
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1228 } |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1229 |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1230 echo |
46138f8478e5
Work on votekey management.
Matti Hamalainen <ccr@tnsp.org>
parents:
266
diff
changeset
|
1231 "</table>\n"; |
116
a95facb41c86
Some preliminary work on the votekey administration backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
113
diff
changeset
|
1232 break; |
a95facb41c86
Some preliminary work on the votekey administration backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
113
diff
changeset
|
1233 } |
105
a85f258f6beb
Move some things around and modularize the code.
Matti Hamalainen <ccr@tnsp.org>
parents:
90
diff
changeset
|
1234 break; |
a85f258f6beb
Move some things around and modularize the code.
Matti Hamalainen <ccr@tnsp.org>
parents:
90
diff
changeset
|
1235 |
0 | 1236 case "compos": |
265 | 1237 echo |
1238 "<form method=\"post\" action=\"\" onsubmit=\"return addCompo()\">\n". | |
1239 " ".stGetFormTextInput(64, SET_LEN_COMPO_NAME, "", "ncname", "", "")."<br />\n". | |
1240 " ".stGetFormTextArea(5, 60, "", "ncdescription", "", "")."<br />\n". | |
1241 " ".stGetFormSubmitInput("nccompo", "Add compo")."\n". | |
1242 " ".stGetFormButtonInput("", "", "", "Clear", "this.form.reset()")."\n". | |
1243 "</form>\n". | |
1244 "<hr />\n"; | |
1245 | |
0 | 1246 $sql = "SELECT * FROM compos ORDER BY id DESC"; |
265 | 1247 foreach (stExecSQL($sql) as $item) |
1248 { | |
1249 echo | |
655
baf2c9608e0a
Add CSS class for compo data blurbs.
Matti Hamalainen <ccr@tnsp.org>
parents:
654
diff
changeset
|
1250 "<div id=\"compo".$item["id"]."\" class=\"compoInfo\">\n". |
265 | 1251 stGetCompoData($item["id"], $item, "co"). |
634 | 1252 "</div>\n"; |
265 | 1253 } |
0 | 1254 break; |
8
4c5f651aa107
Migrate certain settings to SQL database, cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
5
diff
changeset
|
1255 |
223
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1256 case "compo": |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1257 $res = stFetchSQL(stPrepareSQL("SELECT * FROM compos WHERE id=%D", "id")); |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1258 if ($res !== FALSE) |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1259 echo stGetCompoData($res["id"], $res, "co"); |
681 | 1260 else |
1261 stError("No such compo ID!"); | |
223
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1262 break; |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1263 |
624
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1264 case "settingslist": |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1265 $index = 0; |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1266 foreach (stExecSQL("SELECT * FROM settings_groups") as $group) |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1267 { |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1268 if ($index++ > 0) echo ","; |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1269 echo "\"".$group["id"]."\":\"".chentities($group["name"])."\""; |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1270 } |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1271 break; |
352 | 1272 |
8
4c5f651aa107
Migrate certain settings to SQL database, cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
5
diff
changeset
|
1273 case "settings": |
624
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1274 $group = stFetchSQL(stPrepareSQL("SELECT * FROM settings_groups WHERE id=%D", "id")); |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1275 if ($group !== FALSE) |
14
e36c4d2b09c4
Fix settings to work, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
8
diff
changeset
|
1276 { |
624
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1277 $prefix = "st"; |
626
abda11cd3259
Make the settings panels slightly nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
624
diff
changeset
|
1278 $first = TRUE; |
14
e36c4d2b09c4
Fix settings to work, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
8
diff
changeset
|
1279 echo |
624
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1280 "<h1>".chentities($group["description"])."</h1>\n". |
626
abda11cd3259
Make the settings panels slightly nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
624
diff
changeset
|
1281 "<form method=\"post\" action=\"\" onsubmit=\"return jsUpdateSettings(".$group["id"].")\">\n"; |
624
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1282 |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1283 foreach (stExecSQL("SELECT * FROM settings WHERE vtype<>".VT_TEXT." AND vgroup=".$group["id"]." ORDER BY vtype ASC") as $item) |
14
e36c4d2b09c4
Fix settings to work, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
8
diff
changeset
|
1284 { |
626
abda11cd3259
Make the settings panels slightly nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
624
diff
changeset
|
1285 if ($first) |
abda11cd3259
Make the settings panels slightly nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
624
diff
changeset
|
1286 { |
abda11cd3259
Make the settings panels slightly nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
624
diff
changeset
|
1287 echo "<table>\n"; |
abda11cd3259
Make the settings panels slightly nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
624
diff
changeset
|
1288 $first = FALSE; |
abda11cd3259
Make the settings panels slightly nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
624
diff
changeset
|
1289 } |
abda11cd3259
Make the settings panels slightly nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
624
diff
changeset
|
1290 |
624
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1291 echo |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1292 " <tr>\n". |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1293 " <td>"; |
626
abda11cd3259
Make the settings panels slightly nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
624
diff
changeset
|
1294 |
624
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1295 $id = $item["key"]; |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1296 switch ($item["vtype"]) |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1297 { |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1298 case VT_INT: |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1299 echo stGetFormTextInput(10, 10, "", $id, $prefix, $item["vint"]); |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1300 break; |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1301 case VT_STR: |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1302 echo stGetFormTextInput(40, 128, "", $id, $prefix, $item["vstr"]); |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1303 break; |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1304 case VT_BOOL: |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1305 echo stGetFormCheckBoxInput("", $id, $prefix, $item["vint"], ""); |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1306 break; |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1307 } |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1308 echo |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1309 "</td>\n". |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1310 " <td><label for=\"".$prefix.$id."\">".chentities($item["sdesc"])."</label></td>\n". |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1311 " </tr>\n"; |
14
e36c4d2b09c4
Fix settings to work, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
8
diff
changeset
|
1312 } |
626
abda11cd3259
Make the settings panels slightly nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
624
diff
changeset
|
1313 if (!$first) |
abda11cd3259
Make the settings panels slightly nicer.
Matti Hamalainen <ccr@tnsp.org>
parents:
624
diff
changeset
|
1314 echo "</table>\n".stGetSaveButton(); |
14
e36c4d2b09c4
Fix settings to work, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
8
diff
changeset
|
1315 |
624
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1316 foreach (stExecSQL("SELECT * FROM settings WHERE vtype=".VT_TEXT." AND vgroup=".$group["id"]." ORDER BY key DESC") as $item) |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1317 { |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1318 echo |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1319 "<h2>".chentities($item["sdesc"])."</h2>\n". |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1320 stGetFormTextArea(10, 60, "", $item["key"], $prefix, $item["vtext"]). |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1321 "\n<br />\n". |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1322 stGetSaveButton(); |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1323 } |
aad32d21091f
Some work on settings groups.
Matti Hamalainen <ccr@tnsp.org>
parents:
615
diff
changeset
|
1324 echo "</form>\n"; |
14
e36c4d2b09c4
Fix settings to work, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
8
diff
changeset
|
1325 } |
8
4c5f651aa107
Migrate certain settings to SQL database, cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
5
diff
changeset
|
1326 break; |
0 | 1327 |
250
34f540cea1ff
Some work on compo entry listing.
Matti Hamalainen <ccr@tnsp.org>
parents:
249
diff
changeset
|
1328 case "compolist": |
249
6927edc7e266
Get compo name list as JSON.
Matti Hamalainen <ccr@tnsp.org>
parents:
228
diff
changeset
|
1329 $index = 0; |
223
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1330 foreach (stExecSQL("SELECT * FROM compos") as $compo) |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1331 { |
249
6927edc7e266
Get compo name list as JSON.
Matti Hamalainen <ccr@tnsp.org>
parents:
228
diff
changeset
|
1332 if ($index++ > 0) echo ","; |
251
1953d5025531
Alter the JSON format of the compo data list.
Matti Hamalainen <ccr@tnsp.org>
parents:
250
diff
changeset
|
1333 echo "\"".$compo["id"]."\":\"".chentities($compo["name"])."\""; |
223
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1334 } |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1335 break; |
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1336 |
250
34f540cea1ff
Some work on compo entry listing.
Matti Hamalainen <ccr@tnsp.org>
parents:
249
diff
changeset
|
1337 case "entries": |
223
532704115290
Make it possible to update news entries.
Matti Hamalainen <ccr@tnsp.org>
parents:
216
diff
changeset
|
1338 $id = intval(stGetRequestItem("id", 0)); |
250
34f540cea1ff
Some work on compo entry listing.
Matti Hamalainen <ccr@tnsp.org>
parents:
249
diff
changeset
|
1339 if (($compo = stFetchSQL("SELECT * FROM compos WHERE id=".$id)) !== false) |
0 | 1340 { |
381 | 1341 $nentries = stFetchSQLColumn("SELECT COUNT(*) FROM entries WHERE compo_id=".$id); |
1342 $prefix = "ne"; | |
0 | 1343 echo |
677 | 1344 "<h1>#".$id." - ".chentities($compo["name"])." (".$nentries." entries)</h1>\n"; |
385
8b8b0a83233b
Add compo entry show position buttons to individual compos.
Matti Hamalainen <ccr@tnsp.org>
parents:
382
diff
changeset
|
1345 |
8b8b0a83233b
Add compo entry show position buttons to individual compos.
Matti Hamalainen <ccr@tnsp.org>
parents:
382
diff
changeset
|
1346 if ($nentries > 0) |
8b8b0a83233b
Add compo entry show position buttons to individual compos.
Matti Hamalainen <ccr@tnsp.org>
parents:
382
diff
changeset
|
1347 { |
8b8b0a83233b
Add compo entry show position buttons to individual compos.
Matti Hamalainen <ccr@tnsp.org>
parents:
382
diff
changeset
|
1348 echo |
8b8b0a83233b
Add compo entry show position buttons to individual compos.
Matti Hamalainen <ccr@tnsp.org>
parents:
382
diff
changeset
|
1349 stGetFormButtonInput("generate", "", "", " Add missing show positions ", "generateEntryPositions(".$id.", 1)")."\n". |
8b8b0a83233b
Add compo entry show position buttons to individual compos.
Matti Hamalainen <ccr@tnsp.org>
parents:
382
diff
changeset
|
1350 stGetFormButtonInput("regenerate", "", "", " ReGenerate show positions ", "generateEntryPositions(".$id.", 0)")."\n"; |
8b8b0a83233b
Add compo entry show position buttons to individual compos.
Matti Hamalainen <ccr@tnsp.org>
parents:
382
diff
changeset
|
1351 } |
8b8b0a83233b
Add compo entry show position buttons to individual compos.
Matti Hamalainen <ccr@tnsp.org>
parents:
382
diff
changeset
|
1352 |
8b8b0a83233b
Add compo entry show position buttons to individual compos.
Matti Hamalainen <ccr@tnsp.org>
parents:
382
diff
changeset
|
1353 echo |
678 | 1354 "<table class=\"entries\">\n". |
0 | 1355 " <tr>\n". |
113
671330b7f5d1
Add "show_id" to compo entries, to designate the position they were shown at
Matti Hamalainen <ccr@tnsp.org>
parents:
112
diff
changeset
|
1356 " <th style=\"width:4%;\">S#</th>\n". |
264 | 1357 " <th>Name</th>\n". |
29 | 1358 " <th>Author(s)</th>\n". |
59
e5e38ed4e837
Work on compo entry addition and editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
57
diff
changeset
|
1359 " <th>Filename</th>\n". |
215
bfd480370a70
More work on input validation.
Matti Hamalainen <ccr@tnsp.org>
parents:
214
diff
changeset
|
1360 " <th>Info</th>\n". |
0 | 1361 " <th>Actions</th>\n". |
381 | 1362 " </tr>\n". |
1363 " <tr>\n". | |
1364 " <td></td>\n". | |
1365 " <td>".stGetFormTextInput(20, SET_LEN_ENTRY_NAME, "name", $id, $prefix, "")."</td>\n". | |
1366 " <td>".stGetFormTextInput(15, SET_LEN_ENTRY_AUTHOR, "author", $id, $prefix, "")."</td>\n". | |
1367 " <td>".stGetFormTextInput(20, SET_LEN_ENTRY_FILENAME, "filename", $id, $prefix, "")."</td>\n". | |
1368 // " <td>".stGetFormTextInput(20, SET_LEN_ENTRY_INFO, "info", $id, $prefix, "")."</td>\n". | |
1369 " <td>".stGetFormTextArea(2, 30, "info", $id, $prefix, "")."</td>\n". | |
1370 " <td>".stGetFormButtonInput("add", $id, $prefix, "Add new", "addEntry(".$id.")")."</td>\n". | |
1371 " </tr>\n". | |
1372 " <tr><td colspan=\"6\"><hr /></td></tr>\n"; | |
0 | 1373 |
690
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
1374 $row = 0; |
543 | 1375 foreach (stExecSQL("SELECT * FROM entries WHERE compo_id=".$id." ORDER BY id ASC") as $entry) |
690
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
1376 stPrintEntryItemData($entry, $row++, TRUE, "en", $compo["ctype"], FALSE); |
59
e5e38ed4e837
Work on compo entry addition and editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
57
diff
changeset
|
1377 |
0 | 1378 echo |
678 | 1379 "</table>\n"; |
0 | 1380 } |
1381 break; | |
677 | 1382 |
1383 case "entry": | |
1384 $res = stFetchSQL(stPrepareSQL("SELECT * FROM entries WHERE id=%D", "id")); | |
1385 if ($res !== FALSE) | |
690
bad79296eb34
Cleanups, rename variables.
Matti Hamalainen <ccr@tnsp.org>
parents:
689
diff
changeset
|
1386 stPrintEntryItemData($res, -1, FALSE, "en", FALSE, stGetRequestItem("edit", FALSE)); |
681 | 1387 else |
1388 stError("No such entry ID!"); | |
677 | 1389 break; |
0 | 1390 } |
1391 break; | |
1392 | |
1393 case "delete": | |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1394 // |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1395 // Delete entry |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1396 // |
208
8985d2bdb29b
More work on error handling etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
207
diff
changeset
|
1397 if (stChkRequestItem("id", $id, array(CHK_TYPE, VT_INT, "Invalid data."))) |
0 | 1398 { |
1399 if ($type == "news") | |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1400 { |
0 | 1401 $sql = stPrepareSQL("DELETE FROM news WHERE id=%d AND persist=0", $id); |
66
230aacc22cb4
Move some functions to site lib.
Matti Hamalainen <ccr@tnsp.org>
parents:
61
diff
changeset
|
1402 stExecSQLCond($sql, "OK, news item ".$id." deleted."); |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1403 } |
0 | 1404 else |
1405 if ($type == "attendees") | |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1406 { |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1407 // Attendees require some more work |
302
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1408 $sql = stPrepareSQL("SELECT * FROM attendees WHERE id=%d", $id); |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1409 if (($attn = stFetchSQL($sql)) !== false) |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1410 { |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1411 $sql = stPrepareSQL("DELETE FROM attendees WHERE id=%d", $id); |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1412 stExecSQLCond($sql, "OK, attendee ".$id." deleted."); |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1413 |
305
b96c41bd9dd6
More work on admin backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
302
diff
changeset
|
1414 // If assigned votekey mode, delete the key and votes as well |
b96c41bd9dd6
More work on admin backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
302
diff
changeset
|
1415 if ($voteKeyMode == VOTE_ASSIGN && $attn["key_id"] != 0) |
302
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1416 { |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1417 $sql = stPrepareSQL("DELETE FROM votekeys WHERE id=%d", $attn["key_id"]); |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1418 stExecSQLCond($sql, "OK, attendee ".$id." votekey deleted."); |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1419 |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1420 $sql = stPrepareSQL("DELETE FROM votes WHERE key_id=%d", $attn["key_id"]); |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1421 stExecSQLCond($sql, "OK, attendee ".$id." votes deleted."); |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1422 } |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1423 } |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1424 else |
828fc30e3c94
Some work on vote backend stuff.
Matti Hamalainen <ccr@tnsp.org>
parents:
296
diff
changeset
|
1425 stError("No such attendee ID #".$id); |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1426 } |
0 | 1427 else |
1428 if ($type == "entries") | |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1429 { |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1430 // .. as do compo entries |
0 | 1431 $sql = stPrepareSQL("DELETE FROM entries WHERE id=%d", $id); |
66
230aacc22cb4
Move some functions to site lib.
Matti Hamalainen <ccr@tnsp.org>
parents:
61
diff
changeset
|
1432 stExecSQLCond($sql, "OK, entry ".$id." deleted."); |
0 | 1433 |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1434 $sql = stPrepareSQL("DELETE FROM votes WHERE entry_id=%d", $id); |
66
230aacc22cb4
Move some functions to site lib.
Matti Hamalainen <ccr@tnsp.org>
parents:
61
diff
changeset
|
1435 stExecSQLCond($sql, "OK, entry ".$id." votes deleted."); |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1436 } |
608
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1437 else |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1438 if ($type == "compo") |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1439 { |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1440 stDBBeginTransaction(); |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1441 |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1442 // Delete votes for compo entry |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1443 foreach (stExecSQL("SELECT * FROM entries WHERE compo_id=".$id) as $sentry) |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1444 { |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1445 stExecSQLCond( |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1446 "DELETE FROM votes WHERE entry_id=".$sentry["id"], |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1447 "OK, entry ".$sentry["id"]." votes deleted."); |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1448 } |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1449 |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1450 // Delete entries for the compo |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1451 stExecSQLCond( |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1452 "DELETE FROM entries WHERE compo_id=".$id, |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1453 "OK, compo entries for compo ".$id." deleted."); |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1454 |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1455 // Delete the compo itself |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1456 stExecSQLCond( |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1457 "DELETE FROM compos WHERE id=".$id, |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1458 "OK, compo ".$id." deleted."); |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1459 |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1460 stDBCommitTransaction(); |
7d676c77e3f8
Add functionality for deleting a compo.
Matti Hamalainen <ccr@tnsp.org>
parents:
601
diff
changeset
|
1461 } |
0 | 1462 } |
305
b96c41bd9dd6
More work on admin backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
302
diff
changeset
|
1463 else |
b96c41bd9dd6
More work on admin backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
302
diff
changeset
|
1464 if ($type == "votekeys") |
b96c41bd9dd6
More work on admin backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
302
diff
changeset
|
1465 { |
b96c41bd9dd6
More work on admin backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
302
diff
changeset
|
1466 $sql = stPrepareSQL("DELETE FROM votekeys"); |
b96c41bd9dd6
More work on admin backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
302
diff
changeset
|
1467 stExecSQLCond($sql, "OK, all votekeys purged"); |
b96c41bd9dd6
More work on admin backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
302
diff
changeset
|
1468 } |
0 | 1469 break; |
1470 | |
1471 case "add": | |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1472 // |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1473 // Add new entry |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1474 // |
228 | 1475 if ($type == "news" && stValidateRequestNewsData()) |
0 | 1476 { |
1477 $sql = stPrepareSQL( | |
1478 "INSERT INTO news (utime,title,text,author) VALUES (%d,%S,%Q,%S)", | |
1479 time(), "title", "text", "author"); | |
1480 | |
66
230aacc22cb4
Move some functions to site lib.
Matti Hamalainen <ccr@tnsp.org>
parents:
61
diff
changeset
|
1481 stExecSQLCond($sql, "OK, news item added."); |
0 | 1482 } |
1483 else | |
228 | 1484 if ($type == "compo" && stValidateRequestCompoData(FALSE)) |
0 | 1485 { |
1486 $sql = stPrepareSQL( | |
643 | 1487 "INSERT INTO compos (name,description,visible,voting,show_authors) VALUES (%S,%Q,0,0,0)", |
1488 "name", "description"); | |
0 | 1489 |
66
230aacc22cb4
Move some functions to site lib.
Matti Hamalainen <ccr@tnsp.org>
parents:
61
diff
changeset
|
1490 stExecSQLCond($sql, "OK, compo added."); |
0 | 1491 } |
1492 else | |
646
2eeca16e9c96
Improve attendee adding/updating data validation.
Matti Hamalainen <ccr@tnsp.org>
parents:
644
diff
changeset
|
1493 if ($type == "attendees" && stValidateRequestUserData(TRUE, FALSE)) |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1494 { |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1495 $sql = stPrepareSQL( |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1496 "INSERT INTO attendees (regtime,name,groups,oneliner,email) VALUES (%d,%S,%S,%S,%S)", |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1497 time(), "name", "groups", "oneliner", "email"); |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1498 |
66
230aacc22cb4
Move some functions to site lib.
Matti Hamalainen <ccr@tnsp.org>
parents:
61
diff
changeset
|
1499 stExecSQLCond($sql, "OK, attendee added."); |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1500 } |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1501 else |
228 | 1502 if ($type == "entry" && stValidateRequestEntryData($fake)) |
59
e5e38ed4e837
Work on compo entry addition and editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
57
diff
changeset
|
1503 { |
296
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1504 if (stFetchSQLColumn(stPrepareSQL("SELECT id FROM compos WHERE id=%D", "compo_id")) === FALSE) |
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1505 { |
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1506 stError("No such compo ID."); |
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1507 } |
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1508 else |
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1509 { |
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1510 $sql = stPrepareSQL( |
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1511 "INSERT INTO entries (name,author,compo_id,filename,info) VALUES (%S,%S,%D,%S,%Q)", |
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1512 "name", "author", "compo_id", "filename", "info"); |
59
e5e38ed4e837
Work on compo entry addition and editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
57
diff
changeset
|
1513 |
296
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1514 stExecSQLCond($sql, "OK, entry added."); |
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1515 } |
59
e5e38ed4e837
Work on compo entry addition and editing.
Matti Hamalainen <ccr@tnsp.org>
parents:
57
diff
changeset
|
1516 } |
0 | 1517 break; |
1518 | |
1519 case "update": | |
53
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1520 // |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1521 // Update existing entry |
71256605546b
More work on admin interface.
Matti Hamalainen <ccr@tnsp.org>
parents:
52
diff
changeset
|
1522 // |
209 | 1523 if (stChkRequestItem("id", $id, array(CHK_TYPE, VT_INT, "Invalid data."))) |
1524 { | |
627
18f52c7daf77
Make group-specific settings updates possible.
Matti Hamalainen <ccr@tnsp.org>
parents:
626
diff
changeset
|
1525 if ($type == "settings") |
18f52c7daf77
Make group-specific settings updates possible.
Matti Hamalainen <ccr@tnsp.org>
parents:
626
diff
changeset
|
1526 { |
18f52c7daf77
Make group-specific settings updates possible.
Matti Hamalainen <ccr@tnsp.org>
parents:
626
diff
changeset
|
1527 stDBBeginTransaction(); |
18f52c7daf77
Make group-specific settings updates possible.
Matti Hamalainen <ccr@tnsp.org>
parents:
626
diff
changeset
|
1528 foreach (stExecSQL("SELECT * FROM settings WHERE vgroup=".$id) as $item) |
18f52c7daf77
Make group-specific settings updates possible.
Matti Hamalainen <ccr@tnsp.org>
parents:
626
diff
changeset
|
1529 if (($val = stGetRequestItem($item["key"], FALSE)) !== FALSE) |
18f52c7daf77
Make group-specific settings updates possible.
Matti Hamalainen <ccr@tnsp.org>
parents:
626
diff
changeset
|
1530 { |
18f52c7daf77
Make group-specific settings updates possible.
Matti Hamalainen <ccr@tnsp.org>
parents:
626
diff
changeset
|
1531 $sql = "UPDATE settings SET ".stGetSettingSQL($item, $val)." WHERE key=".$db->quote($item["key"]); |
666 | 1532 stExecSQL($sql); |
627
18f52c7daf77
Make group-specific settings updates possible.
Matti Hamalainen <ccr@tnsp.org>
parents:
626
diff
changeset
|
1533 } |
18f52c7daf77
Make group-specific settings updates possible.
Matti Hamalainen <ccr@tnsp.org>
parents:
626
diff
changeset
|
1534 stDBCommitTransaction(); |
666 | 1535 stSetStatus(200, "Updated settings."); |
627
18f52c7daf77
Make group-specific settings updates possible.
Matti Hamalainen <ccr@tnsp.org>
parents:
626
diff
changeset
|
1536 } |
18f52c7daf77
Make group-specific settings updates possible.
Matti Hamalainen <ccr@tnsp.org>
parents:
626
diff
changeset
|
1537 else |
646
2eeca16e9c96
Improve attendee adding/updating data validation.
Matti Hamalainen <ccr@tnsp.org>
parents:
644
diff
changeset
|
1538 if ($type == "attendees" && stValidateRequestUserData(TRUE, $id)) |
209 | 1539 { |
1540 $sql = stPrepareSQLUpdate("attendees", | |
435 | 1541 "WHERE id=".$id, |
209 | 1542 array( |
1543 "name" => "S", | |
1544 "groups" => "S", | |
1545 "email" => "S", | |
1546 "oneliner" => "S", | |
1547 )); | |
1548 | |
1549 stExecSQLCond($sql, "OK, attendee updated."); | |
1550 } | |
1551 else | |
228 | 1552 if ($type == "news" && stValidateRequestNewsData()) |
209 | 1553 { |
1554 $sql = stPrepareSQLUpdate("news", | |
435 | 1555 "WHERE id=".$id, |
209 | 1556 array( |
1557 "title" => "S", | |
1558 "text" => "Q", | |
1559 "author" => "S" | |
1560 )); | |
1561 | |
1562 stExecSQLCond($sql, "OK, news item updated."); | |
1563 } | |
1564 else | |
649 | 1565 if ($type == "compotype" && |
1566 stChkRequestItem("ctype", $compotype, | |
1567 array(CHK_RANGE, VT_INT, array(COMPO_NORMAL, COMPO_ASSIGN), "Invalid compo type.") | |
1568 )) | |
644
de35a9743557
Implement changing of compo type.
Matti Hamalainen <ccr@tnsp.org>
parents:
643
diff
changeset
|
1569 { |
649 | 1570 $sql = stPrepareSQL("UPDATE compos SET ctype=%d WHERE id=%d", $compotype, $id); |
644
de35a9743557
Implement changing of compo type.
Matti Hamalainen <ccr@tnsp.org>
parents:
643
diff
changeset
|
1571 stExecSQLCond($sql, "OK, compo updated."); |
de35a9743557
Implement changing of compo type.
Matti Hamalainen <ccr@tnsp.org>
parents:
643
diff
changeset
|
1572 } |
de35a9743557
Implement changing of compo type.
Matti Hamalainen <ccr@tnsp.org>
parents:
643
diff
changeset
|
1573 else |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
1574 if ($type == "compo") |
209 | 1575 { |
654 | 1576 // Check if compo ID exists |
1577 if (($compo = stFetchSQL("SELECT * FROM compos WHERE id=".$id)) === false) | |
1578 stError("No such compo ID."); | |
1579 else | |
1580 if (stValidateRequestCompoData(TRUE, $compo["ctype"])) | |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
1581 { |
654 | 1582 $skeys = array( |
1583 "name" => "S", | |
1584 "description" => "Q", | |
1585 "visible" => "B", | |
1586 "show_authors" => "B", | |
1587 "cpath" => "S", | |
1588 ); | |
1589 | |
1590 switch ($compo["ctype"]) | |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
1591 { |
654 | 1592 case COMPO_NORMAL: |
1593 $skeys["voting"] = "B"; | |
1594 break; | |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
1595 } |
654 | 1596 |
1597 $sql = stPrepareSQLUpdate("compos", "WHERE id=".$id, $skeys); | |
1598 stExecSQLCond($sql, "OK, compo updated."); | |
651
ad266a57eb23
Improve compo data updates.
Matti Hamalainen <ccr@tnsp.org>
parents:
649
diff
changeset
|
1599 } |
209 | 1600 } |
1601 else | |
228 | 1602 if ($type == "entry" && stValidateRequestEntryData($compo_id)) |
209 | 1603 { |
214 | 1604 if (stFetchSQLColumn("SELECT id FROM compos WHERE id=".$compo_id) === FALSE) |
209 | 1605 { |
214 | 1606 stError("No such compo ID."); |
209 | 1607 } |
1608 else | |
1609 { | |
1610 $sql = stPrepareSQLUpdate("entries", | |
435 | 1611 "WHERE id=".$id, |
209 | 1612 array( |
1613 "name" => "S", | |
1614 "author" => "S", | |
1615 "filename" => "S", | |
296
bbdf1b9c5a07
Check compo_id in compo entry addition.
Matti Hamalainen <ccr@tnsp.org>
parents:
289
diff
changeset
|
1616 "info" => "Q", |
209 | 1617 "compo_id" => "D", |
1618 )); | |
1619 | |
1620 stExecSQLCond($sql, "OK, entry updated."); | |
1621 } | |
1622 } | |
435 | 1623 } |
1624 break; | |
1625 | |
1626 case "votekey": | |
1627 if (stChkRequestItem("id", $id, array(CHK_TYPE, VT_INT, "Invalid data."))) | |
1628 { | |
1629 switch ($type) | |
308
3cfd95758377
A bit of work on vote key management backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
305
diff
changeset
|
1630 { |
435 | 1631 case "assign": |
1632 // Check if already assigned to someone .. | |
1633 $key_id = intval(stGetRequestItem("key_id", 0)); | |
1634 $sql = stPrepareSQL("SELECT * FROM votekeys WHERE id=%d", $key_id); | |
1635 if (stFetchSQL($sql) === false) | |
1636 stError("Invalid key ID #."); | |
1637 else | |
1638 { | |
1639 $sql = stPrepareSQL("SELECT * FROM attendees WHERE key_id=%d", $key_id); | |
1640 if (($attn = stFetchSQL($sql)) !== false && $attn["id"] != $id) | |
1641 stError("That key has already been assigned to another attendee!"); | |
319
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
1642 else |
312 | 1643 { |
435 | 1644 // Assign .. |
1645 $sql = stPrepareSQL("UPDATE attendees SET key_id=%d WHERE id=%d", $key_id, $id); | |
1646 stExecSQLCond($sql, "Assigned key updated."); | |
312 | 1647 } |
435 | 1648 } |
1649 break; | |
319
623acd958944
Simplify things, add clear button to vote key assignation.
Matti Hamalainen <ccr@tnsp.org>
parents:
318
diff
changeset
|
1650 |
435 | 1651 case "clear": |
1652 $sql = stPrepareSQL("UPDATE attendees SET key_id=NULL WHERE id=%d", $id); | |
1653 stExecSQLCond($sql, "Assigned key cleared."); | |
1654 break; | |
1655 | |
1656 case "active": | |
1657 // Autobots activate! | |
1658 $sql = stPrepareSQL("UPDATE votekeys SET active=%B WHERE id=%d", "active", $id); | |
1659 stExecSQLCond($sql, "Votekey status changed."); | |
1660 break; | |
308
3cfd95758377
A bit of work on vote key management backend.
Matti Hamalainen <ccr@tnsp.org>
parents:
305
diff
changeset
|
1661 } |
209 | 1662 } |
0 | 1663 break; |
1664 | |
1665 default: | |
66
230aacc22cb4
Move some functions to site lib.
Matti Hamalainen <ccr@tnsp.org>
parents:
61
diff
changeset
|
1666 stSetStatus(404, "Not Found"); |
0 | 1667 break; |
1668 } | |
1669 | |
378 | 1670 if (!$errorSet) |
1671 stSaveDisplayVars(); | |
1672 | |
544 | 1673 |
1674 if ($errorSet) | |
1675 { | |
1676 ob_clean(); | |
1677 stDumpAJAXStatusErrors(); | |
1678 } | |
1679 | |
1680 ob_end_flush(); | |
0 | 1681 ?> |