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

Revision 6087, 7.8 KB checked in by naka, 20 years ago (diff)

* empty log message *

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