위젯 핸들링 하는 부분을 수정하여 페이지 수정시 위젯을 추가하게 되면 해당 페이지를 다시 읽어 플래시파일등의 추가 및 css의 오류가 없도록 수정

git-svn-id: http://xe-core.googlecode.com/svn/sandbox@3603 201d5d3c-b55e-5fd7-737f-ddc643e51545
This commit is contained in:
zero 2008-01-28 06:11:00 +00:00
parent de2a43eb43
commit 95cfcf7f83
10 changed files with 209 additions and 215 deletions

View file

@ -1,9 +1,8 @@
<!--%import("filter/add_content.xml")-->
<!--%import("js/widget.js")-->
<!--%import("css/widget.css")-->
<div class="pageAddContent"></div>
<form action="./" method="get" onsubmit="return procFilter(this, add_content);" id="content_fo">
<form action="./" method="get" onsubmit="return completeAddContent(this); return false;" id="content_fo">
<input type="hidden" name="content" value="" />
<input type="hidden" name="mid" value="{$module_info->mid}" />
<input type="hidden" name="module_srl" value="{$module_srl}" />

View file

@ -49,7 +49,7 @@ function getPadding(obj, direct) {
}
/* 위젯 배치 시작을 함 */
/* 위젯 핸들링 시작 */
var zonePageObj = null;
var zoneModuleSrl = 0;
function doStartPageModify(zoneID, module_srl) {
@ -155,8 +155,7 @@ function getWidgetCode(childObj, widget) {
var value = childObj.attributes[i].nodeValue;
if(!value) continue;
if(value && typeof(value)=="string") value = value.replace(/\"/ig,'&quot;');
attrs += name+'="'+value+'" ';
attrs += name+'="'+escape(value)+'" ';
}
var style = childObj.getAttribute("style");
return '<img class="zbxe_widget_output" style="'+getStyle(childObj)+'" widget="'+widget+'" '+attrs+' />';
@ -196,11 +195,28 @@ function doSyncPageContent() {
}
// 부모창에 위젯을 추가
function completeAddContent(ret_obj) {
var tpl = ret_obj["tpl"];
function completeAddContent(fo_obj) {
var editor_sequence = fo_obj.getAttribute('editor_sequence');
var content = editorGetContent(editor_sequence);
var tpl = ''+
'<div class="widgetOutput" style="'+fo_obj.style.value+'" widget_padding_left="'+fo_obj.widget_padding_left.value+'" widget_padding_right="'+fo_obj.widget_padding_right.value+'" widget_padding_top="'+fo_obj.widget_padding_top.value+'" widget_padding_bottom="'+fo_obj.widget_padding_bottom.value+'" widget="widgetContent">'+
'<div class="widgetSetup"></div>'+
'<div class="widgetCopy"></div>'+
'<div class="widgetSize"></div>'+
'<div class="widgetRemove"></div>'+
'<div class="widgetResize"></div>'+
'<div class="widgetResizeLeft"></div>'+
'<div class="widgetBorder">'+
'<div style="padding:'+fo_obj.widget_padding_top.value+'px '+fo_obj.widget_padding_right.value+'px'+fo_obj.widget_padding_bottom.value+'px'+fo_obj.widget_padding_left.value+'px">'+
content+
'</div><div class="clear"></div>'+
'</div>'+
'<div class="widgetContent" style="display:none;width:1px;height:1px;overflow:hidden;">'+Base64.encode(content)+'</div>'+
'</div>';
opener.doAddWidgetCode(tpl);
window.close();
return false;
}
/* 박스 위젯 추가 */
@ -259,6 +275,7 @@ function doAddWidgetCode(widget_code) {
var nodes = dummy.childNodes;
var zoneObj = xGetElementById('zonePageContent');
zoneObj.style.visibility = 'hidden';
if(selectedWidget && selectedWidget.getAttribute("widget")) {
while ( nodes.length ) {
@ -273,7 +290,13 @@ function doAddWidgetCode(widget_code) {
}
}
doFitBorderSize();
// 위젯 추가후 페이지 리로딩
var tpl = getWidgetContent();
var fo_obj = xGetElementById('pageFo');
fo_obj.content.value = tpl;
fo_obj.submit();
}
// 클릭 이벤트시 위젯의 수정/제거/이벤트 무효화 처리

View file

@ -102,7 +102,10 @@ function doFillWidgetVars() {
case "text" :
case "textarea" :
var val = selected_node.getAttribute(name);
if(val) node.value = val;
if(!val) continue;
var unescaped_val = unescape(val);
if(!unescaped_val) node.value = val;
else node.value = unescaped_val;
break;
case "checkbox" :
if(selected_node.getAttribute(name)) {

View file

@ -130,34 +130,12 @@
$this->add('colorset_list', $colorsets);
}
/**
* @brief 직접 내용 입력된 위젯의 처리
**/
function procWidgetAddContent() {
$content = Context::get('content');
$args = Context::getRequestVars('style','widget_padding_left','widget_padding_right','widget_padding_bottom','widget_padding_top');
$tpl = $this->transEditorContent($content, $args);
$this->add('tpl', $tpl);
}
/**
* @breif 특정 content의 위젯 태그들을 변환하여 return
**/
function transWidgetCode($content, $include_info = false) {
$this->include_info = $include_info;
// 내용중 widget이 아닌 것들을 일단 분리
/*
$none_widget_code = preg_replace('!<img([^\>]*)widget=([^\>]*?)\>!is', '', $content);
$oPageAdminController = &getAdminController('page');
if(trim($none_widget_code)) {
$args->style = "float:left;overflow:hidden;padding:none;padding:none";
$args->widget_padding_left = $args->widget_padding_top = $args->widget_padding_right = $args->widget_padding_bottom = 0;
$none_widget_content = $oPageAdminController->transEditorContent($none_widget_code, $args);
}
*/
$this->include_info = $include_info;
// 내용중 위젯을 또다시 구함 (기존 버전에서 페이지 수정해 놓은것과의 호환을 위해서)
$content = preg_replace_callback('!<img([^\>]*)widget=([^\>]*?)\>!is', array($this,'transWidget'), $content);
@ -165,17 +143,6 @@
// 박스 위젯을 다시 구함
$content = preg_replace_callback('!<div([^\>]*)widget=([^\>]*?)\><div><div>!is', array($this,'transWidgetBox'), $content);
// include_info, 즉 위젯의 수정일 경우 css와 js파일을 추가해 주고 위젯 수정용 레이어도 추가함
if($this->include_info) {
Context::addJsFile("./modules/widget/tpl/js/widget.js");
Context::addCSSFile("./modules/widget/tpl/css/widget.css");
$oTemplate = &TemplateHandler::getInstance();
$tpl = $oTemplate->compile($this->module_path.'tpl', 'widget_layer');
$content .= $tpl;
}
return $content;
}
@ -183,10 +150,7 @@
* @brief 위젯 코드를 실제 php코드로 변경
**/
function transWidget($matches) {
$oContext = &Context::getInstance();
$buff = trim($matches[0]);
$buff = preg_replace_callback('/([^=^"^ ]*)=([^ ^>]*)/i', array($oContext, _fixQuotation), $buff);
$buff = str_replace("&","&amp;",$buff);
$oXmlParser = new XmlParser();
$xml_doc = $oXmlParser->parse(trim($buff));
@ -196,14 +160,6 @@
if(!$vars->widget) return "";
// 캐시 체크
$widget_sequence = $vars->widget_sequence;
$widget_cache = $vars->widget_cache;
if($widget_cache && $widget_sequence && !$this->include_info) {
$output = WidgetHandler::getCache($widget_sequence, $widget_cache);
if($output) return $output;
}
// 위젯의 이름을 구함
$widget = $vars->widget;
unset($vars->widget);
@ -229,54 +185,5 @@
return WidgetHandler::execute($widget, $vars, $this->include_info);
}
/**
* @brief 에디터에서 생성한 컨텐츠를 페이지 수정시 사용할 있도록 코드 생성
**/
function transEditorContent($content, $args = null) {
// 에디터의 내용을 변환하여 visual한 영역과 원본 소스를 가지고 있는 code로 분리
$code = $content;
$oContext = &Context::getInstance();
$content = preg_replace_callback('!<div([^\>]*)editor_component=([^\>]*)>(.*?)\<\/div\>!is', array($oContext,'transEditorComponent'), $content);
$content = preg_replace_callback('!<img([^\>]*)editor_component=([^\>]*?)\>!is', array($oContext,'transEditorComponent'), $content);
// 결과물에 있는 css Meta 목록을 구해와서 해당 css를 아예 읽어버림
require_once("./classes/optimizer/Optimizer.class.php");
$oOptimizer = new Optimizer();
preg_match_all('!<\!\-\-Meta:([^\-]*?)\-\->!is', $content, $matches);
$css_header = null;
for($i=0;$i<count($matches[1]);$i++) {
$css_file = $matches[1][$i];
$buff = FileHandler::readFile($css_file);
$css_header .= $oOptimizer->replaceCssPath($css_file, $buff)."\n";
}
$tpl = sprintf(
'<style type="text/css">%s</style>'.
'<div class="widgetOutput" style="%s" widget_padding_left="%s" widget_padding_right="%s" widget_padding_top="%s" widget_padding_bottom="%s" widget="widgetContent">'.
'<div class="widgetSetup"></div>'.
'<div class="widgetCopy"></div>'.
'<div class="widgetSize"></div>'.
'<div class="widgetRemove"></div>'.
'<div class="widgetResize"></div>'.
'<div class="widgetResizeLeft"></div>'.
'<div class="widgetBorder">'.
'<div style="padding:%s %s %s %s;">'.
'%s'.
'</div><div class="clear"></div>'.
'</div>'.
'<div class="widgetContent" style="display:none;width:1px;height:1px;overflow:hidden;">%s</div>'.
'</div>',
$css_header,
$args->style,
$args->widget_padding_left, $args->widget_padding_right, $args->widget_padding_top, $args->widget_padding_bottom,
$args->widget_padding_top, $args->widget_padding_right, $args->widget_padding_bottom, $args->widget_padding_left,
$content,
base64_encode($code)
);
return $tpl;
}
}
?>