upload_target_srl = $upload_target_srl; $this->component_path = $component_path; } /** * @brief 에디터에서 처음 요청을 받을 경우 실행이 되는 부분이다. * execute의 경우 2가지 경우가 생긴다. * 직접 에디터 아래의 component area로 삽입할 html 코드를 만드는 것과 popup 윈도우를 띄우는 것인데 * popup윈도우를 띄울 경우는 getPopupContent() 이라는 method가 실행이 되니 구현하여 놓아야 한다 **/ function execute() { $url = sprintf('./?module=editor&act=dispPopup&target_srl=%s&component=multimedia_link', $this->upload_target_srl); $this->add('tpl', ''); $this->add('open_window', 'Y'); $this->add('popup_url', $url); } /** * @brief popup window요청시 다시 call이 될 method. popup window에 출력할 내용을 추가하면 된다 **/ function getPopupContent() { // 템플릿을 미리 컴파일해서 컴파일된 소스를 return $tpl_path = $this->component_path.'tpl'; $tpl_file = 'popup.html'; Context::set("tpl_path", $tpl_path); require_once("./classes/template/TemplateHandler.class.php"); $oTemplate = new TemplateHandler(); return $oTemplate->compile($tpl_path, $tpl_file); } /** * @brief 에디터 컴포넌트가 별도의 고유 코드를 이용한다면 그 코드를 html로 변경하여 주는 method * * 이미지나 멀티미디어, 설문등 고유 코드가 필요한 에디터 컴포넌트는 고유코드를 내용에 추가하고 나서 * DocumentModule::transContent() 에서 해당 컴포넌트의 transHtml() method를 호출하여 고유코드를 html로 변경 **/ function transHTML($xml_obj) { $src = $xml_obj->attrs->src; $width = $xml_obj->attrs->width; if(!$width) $width = 640; $height = $xml_obj->attrs->height; if(!$height) $height = 480; $auto_start = $xml_obj->attrs->auto_start; if($auto_start!="true") $auto_start = "false"; else $auto_start = "true"; $caption = $xml_obj->body; $src = str_replace(array('&','"'), array('&','&qout;'), $src); return sprintf("", $src, $width, $height, $auto_start); } } ?>