source: temp/trunk/html/admin/design/bloc.php @ 3572

Revision 3572, 7.0 KB checked in by kakinaka, 20 years ago (diff)

blank

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1<?php
2
3require_once("../../require.php");
4
5class LC_Page {
6    var $arrForm;
7    var $arrHidden;
8
9    function LC_Page() {
10        $this->tpl_mainpage = 'design/bloc.tpl';
11        $this->tpl_subnavi = 'design/subnavi.tpl';
12        $this->tpl_subno_edit = 'bloc';
13        $this->text_row = 13;
14        $this->tpl_subno = "bloc"; 
15        $this->tpl_mainno = "design";
16        $this->tpl_subtitle = '¥Ö¥í¥Ã¥¯ÊÔ½¸';
17    }
18}
19
20$objPage = new LC_Page();
21$objView = new SC_AdminView();
22
23// ǧ¾Ú²ÄÈݤÎȽÄê
24$objSess = new SC_Session();
25sfIsSuccess($objSess);
26
27// ¥Ö¥í¥Ã¥¯°ìÍ÷¤ò¼èÆÀ
28$objPage->arrBlocList = lfgetBlocData();
29
30// ¥Ö¥í¥Ã¥¯ID¤ò¼èÆÀ
31if (isset($_POST['bloc_id'])) {
32    $bloc_id = $_POST['bloc_id'];
33}else if ($_GET['bloc_id']){
34    $bloc_id = $_GET['bloc_id'];
35}else{
36    $bloc_id = '';
37}
38$objPage->bloc_id = $bloc_id;
39
40// bloc_id ¤¬»ØÄꤵ¤ì¤Æ¤¤¤ë¾ì¹ç¤Ë¤Ï¥Ö¥í¥Ã¥¯¥Ç¡¼¥¿¤Î¼èÆÀ
41if ($bloc_id != '') {
42    $arrBlocData = lfgetBlocData(" bloc_id = ? " , array($bloc_id));
43    $arrBlocData[0]['tpl_path'] = ROOT_DIR . $arrBlocData[0]['tpl_path'];
44
45    // ¥Æ¥ó¥×¥ì¡¼¥È¥Õ¥¡¥¤¥ë¤ÎÆÉ¤ß¹þ¤ß
46    $arrBlocData[0]['tpl_data'] = file_get_contents($arrBlocData[0]['tpl_path']);
47    $objPage->arrBlocData = $arrBlocData[0];
48}
49
50// ¥Ç¡¼¥¿ÅÐÏ¿½èÍý
51if ($_POST['mode'] == 'confirm') {
52   
53    // ¥¨¥é¡¼¥Á¥§¥Ã¥¯
54    $objPage->arrErr = lfErrorCheck($_POST);
55
56    // ¥¨¥é¡¼¤¬¤Ê¤±¤ì¤Ð¹¹¿·½èÍý¤ò¹Ô¤¦   
57    if (count($objPage->arrErr) == 0) {
58   
59       
60        // DB¤Ø¥Ç¡¼¥¿¤ò¹¹¿·¤¹¤ë
61        lfEntryBlocData($_POST);
62       
63        // ¥Õ¥¡¥¤¥ë¤Îºï½ü
64        $del_file=ROOT_DIR . BLOC_DIR . $arrBlocData[0]['filename']. '.tpl';
65        if (file_exists($del_file)) {
66            unlink($del_file);
67        }
68       
69        // ¥Õ¥¡¥¤¥ëºîÀ®
70        $fp = fopen(ROOT_DIR . BLOC_DIR . $_POST['filename'] . '.tpl',"w");
71        fwrite($fp, $_POST['bloc_html']);
72        fclose($fp);
73       
74        $arrBlocData = lfgetBlocData(" filename = ? " , array($_POST['filename']));
75           
76        $bloc_id = $arrBlocData[0]['bloc_id']; 
77        header("location: ./bloc.php?bloc_id=$bloc_id&msg=on");
78        ");
79    }else{
80        // ¥¨¥é¡¼¤¬¤¢¤ì¤ÐÆþÎÏ»þ¤Î¥Ç¡¼¥¿¤òɽ¼¨¤¹¤ë
81        $objPage->arrBlocData = $_POST;
82    }
83}
84
85// ¥Ç¡¼¥¿ºï½ü½èÍý
86if ($_POST['mode'] == 'delete') {
87   
88    // DB¤Ø¥Ç¡¼¥¿¤ò¹¹¿·¤¹¤ë
89    $objDBConn = new SC_DbConn;     // DBÁàºî¥ª¥Ö¥¸¥§¥¯¥È
90    $sql = "";                      // ¥Ç¡¼¥¿¹¹¿·SQLÀ¸À®ÍÑ
91    $ret = "";                      // ¥Ç¡¼¥¿¹¹¿··ë²Ì³ÊǼÍÑ
92    $arrDelData = array();          // ¹¹¿·¥Ç¡¼¥¿À¸À®ÍÑ
93   
94    // ¹¹¿·¥Ç¡¼¥¿À¸À®
95    $arrUpdData = array($arrData['bloc_name'], BLOC_DIR . $arrData['filename'] . '.tpl', $arrData['filename']);
96   
97    // bloc_id ¤¬¶õ¤Ç¤Ê¤¤¾ì¹ç¤Ë¤Ïdelete¤ò¼Â¹Ô
98    if ($_POST['bloc_id'] !== '') {
99        // SQLÀ¸À®
100        $sql = " DELETE FROM dtb_bloc WHERE bloc_id = ?";
101        // SQL¼Â¹Ô
102        $ret = $objDBConn->query($sql,array($_POST['bloc_id']));
103       
104        // ¥Ú¡¼¥¸¤ËÇÛÃÖ¤µ¤ì¤Æ¤¤¤ë¥Ç¡¼¥¿¤âºï½ü¤¹¤ë
105        $sql = "DELETE FROM dtb_blocposition WHERE bloc_id = ?";
106        // SQL¼Â¹Ô
107        $ret = $objDBConn->query($sql,array($_POST['bloc_id']));
108   
109        // ¥Õ¥¡¥¤¥ë¤Îºï½ü
110        $del_file = ROOT_DIR . BLOC_DIR . $arrBlocData[0]['filename']. '.tpl';
111        if(file_exists($del_file)){
112            unlink($del_file);
113        }
114    }
115
116    header("location: ./bloc.php");
117}
118
119
120// ²èÌ̤Îɽ¼¨
121$objView->assignobj($objPage);
122$objView->display(MAIN_FRAME);
123
124//---------------------------------------------------------------------------------------------------------------------------------------------------------
125
126/**************************************************************************************************************
127 * ´Ø¿ô̾   ¡§lfgetBlocData
128 * ½èÍýÆâÍÆ ¡§¥Ö¥í¥Ã¥¯¾ðÊó¤ò¼èÆÀ¤¹¤ë
129 * °ú¿ô1    ¡§$where  ޥޥޥ Where¶çʸ
130 * °ú¿ô2    ¡§$arrVal ޥޥޥ Where¶ç¤Î¹Ê¹þ¾ò·ïÃÍ
131 * Ìá¤êÃÍ   ¡§¥Ö¥í¥Ã¥¯¾ðÊó
132 **************************************************************************************************************/
133function lfgetBlocData($where = '', $arrVal = ''){
134    $objDBConn = new SC_DbConn;     // DBÁàºî¥ª¥Ö¥¸¥§¥¯¥È
135    $sql = "";                      // ¥Ç¡¼¥¿¼èÆÀSQLÀ¸À®ÍÑ
136    $arrRet = array();              // ¥Ç¡¼¥¿¼èÆÀÍÑ
137   
138    // SQLÀ¸À®
139    $sql = " SELECT ";
140    $sql .= "   bloc_id";
141    $sql .= "   ,bloc_name";
142    $sql .= "   ,tpl_path";
143    $sql .= "   ,filename";
144    $sql .= "   ,create_date";
145    $sql .= "   ,update_date";
146    $sql .= "   ,php_path";
147    $sql .= "   ,del_flg";
148    $sql .= " FROM ";
149    $sql .= "   dtb_bloc";
150
151    // where¶ç¤Î»ØÄ꤬¤¢¤ì¤ÐÄɲà  
152    if ($where != '') {
153        $sql .= " WHERE " . $where;
154    }
155   
156    $sql .= " ORDER BY  bloc_id";
157   
158    $arrRet = $objDBConn->getAll($sql, $arrVal);
159   
160    return $arrRet;
161}
162
163/**************************************************************************************************************
164 * ´Ø¿ô̾   ¡§lfEntryBlocData
165 * ½èÍýÆâÍÆ ¡§¥Ö¥í¥Ã¥¯¾ðÊó¤ò¹¹¿·¤¹¤ë
166 * °ú¿ô1    ¡§$arrData  ޥޥޥ ¹¹¿·¥Ç¡¼¥¿
167 * Ìá¤êÃÍ   ¡§¹¹¿··ë²Ì
168 **************************************************************************************************************/
169function lfEntryBlocData($arrData){
170    $objDBConn = new SC_DbConn;     // DBÁàºî¥ª¥Ö¥¸¥§¥¯¥È
171    $sql = "";                      // ¥Ç¡¼¥¿¹¹¿·SQLÀ¸À®ÍÑ
172    $ret = "";                      // ¥Ç¡¼¥¿¹¹¿··ë²Ì³ÊǼÍÑ
173    $arrUpdData = array();          // ¹¹¿·¥Ç¡¼¥¿À¸À®ÍÑ
174    $arrChk = array();              // ÇÓ¾¥Á¥§¥Ã¥¯ÍÑ
175   
176    // ¹¹¿·¥Ç¡¼¥¿À¸À®
177    $arrUpdData = array($arrData['bloc_name'], BLOC_DIR . $arrData['filename'] . '.tpl', $arrData['filename']);
178   
179    // ¥Ç¡¼¥¿¤¬Â¸ºß¤·¤Æ¤¤¤ë¤«¥Á¥§¥Ã¥¯¤ò¹Ô¤¦
180    if($arrData['bloc_id'] !== ''){
181        $arrChk = lfgetBlocData("bloc_id = ?", array($arrData['bloc_id']));
182    }
183   
184    // bloc_id ¤¬¶õ ¼ã¤·¤¯¤Ï ¥Ç¡¼¥¿¤¬Â¸ºß¤·¤Æ¤¤¤Ê¤¤¾ì¹ç¤Ë¤ÏINSERT¤ò¹Ô¤¦
185    if ($arrData['bloc_id'] === '' or !isset($arrChk[0])) {
186        // SQLÀ¸À®
187        $sql = " INSERT INTO dtb_bloc";
188        $sql .= " ( ";
189        $sql .= "     bloc_name ";      // ¥Ö¥í¥Ã¥¯Ì¾¾Î
190        $sql .= "     ,tpl_path ";      // ¥Æ¥ó¥×¥ì¡¼¥ÈÊݸÀè
191        $sql .= "     ,filename ";      // ¥Õ¥¡¥¤¥ë̾¾Î
192        $sql .= " ) VALUES ( ?,?,? )";
193        $sql .= " ";
194    }else{
195        // ¥Ç¡¼¥¿¤¬Â¸ºß¤·¤Æ¤ë¾ì¹ç¤Ë¤Ï¥¢¥Ã¥×¥Ç¡¼¥È¤ò¹Ô¤¦
196        // SQLÀ¸À®
197        $sql = " UPDATE dtb_bloc";
198        $sql .= " SET";
199        $sql .= "     bloc_name = ? ";  // ¥Ö¥í¥Ã¥¯Ì¾¾Î
200        $sql .= "     ,tpl_path = ? ";  // ¥Æ¥ó¥×¥ì¡¼¥ÈÊݸÀè
201        $sql .= "     ,filename = ? ";  // ¥Æ¥ó¥×¥ì¡¼¥È¥Õ¥¡¥¤¥ë̾
202        $sql .= "     ,update_date = now()";
203        $sql .= " WHERE bloc_id = ?";
204        $sql .= " ";
205       
206        // ¹¹¿·¥Ç¡¼¥¿¤Ë¥Ö¥í¥Ã¥¯ID¤òÄɲÃ
207        array_push($arrUpdData, $arrData['bloc_id']);
208    }
209   
210    // SQL¼Â¹Ô
211    $ret = $objDBConn->query($sql,$arrUpdData);
212   
213    return $ret;
214
215}
216
217/**************************************************************************************************************
218 * ´Ø¿ô̾   ¡§lfErrorCheck
219 * ½èÍýÆâÍÆ ¡§ÆþÎϹàÌܤΥ¨¥é¡¼¥Á¥§¥Ã¥¯¤ò¹Ô¤¦
220 * °ú¿ô1    ¡§$arrData  ޥޥޥ ÆþÎϥǡ¼¥¿
221 * Ìá¤êÃÍ   ¡§¥¨¥é¡¼¾ðÊó
222 **************************************************************************************************************/
223function lfErrorCheck($array) {
224    global $objPage;
225    $objErr = new SC_CheckError($array);
226   
227    $objErr->doFunc(array("¥Ö¥í¥Ã¥¯Ì¾", "bloc_name", STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
228    $objErr->doFunc(array("¥Õ¥¡¥¤¥ë̾", "filename", STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "MAX_LENGTH_CHECK","ALNUM_CHECK"));
229   
230    // Ʊ°ì¤Î¥Õ¥¡¥¤¥ë̾¤¬Â¸ºß¤·¤Æ¤¤¤ë¾ì¹ç¤Ë¤Ï¥¨¥é¡¼
231    if(!isset($objErr->arrErr['filename']) and $array['filename'] !== ''){
232        $arrChk = lfgetBlocData("filename = ?", array($array['filename']));
233       
234        if (count($arrChk[0]) >= 1 and $arrChk[0]['bloc_id'] != $array['bloc_id']) {
235            $objErr->arrErr['filename'] = '¢¨ Ʊ¤¸¥Õ¥¡¥¤¥ë̾¤Î¥Ç¡¼¥¿¤¬Â¸ºß¤·¤Æ¤¤¤Þ¤¹¡£Ê̤Î̾¾Î¤òÉÕ¤±¤Æ¤¯¤À¤µ¤¤¡£';
236        }
237    }
238   
239    return $objErr->arrErr;
240}
Note: See TracBrowser for help on using the repository browser.