테스트 사이트 - 개발 중인 베타 버전입니다

댓글 에디터 채택완료

대전댁2 3년 전 조회 3,699

URL 주소 있는곳에서 다운받아서 댓글 에디터 적용하니 적용은 잘 되는데 답변.수정.삭제가 한쪽으로 치우치는데 어떻게 정렬해야 제대로 가능할까요?

 

</p>

<p><?php

if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가

include_once(G5_EDITOR_LIB);

include_once(G5_PLUGIN_PATH.'/jquery-ui/datepicker.php');

$is_dhtml_editor = true;

?></p>

<p><script>

// 글자수 제한

var char_min = parseInt(<?php echo $comment_min ?>); // 최소

var char_max = parseInt(<?php echo $comment_max ?>); // 최대

</script></p>

<p><!-- 댓글 시작 { -->

<section id="bo_vc">

    <h2>댓글목록</h2>

    <?php

    $cmt_amt = count($list);

    for ($i=0; $i<$cmt_amt; $i++) {

        $comment_id = $list[$i]['wr_id'];

        $cmt_depth = ""; // 댓글단계

        $cmt_depth = strlen($list[$i]['wr_comment_reply']) * 20;

        $comment = $list[$i]['content'];

        /*

        if (strstr($list[$i]['wr_option'], "secret")) {

            $str = $str;

        }

        */

        $comment = preg_replace("/\[\<a\s.*href\=\"(http|https|ftp|mms)\:\/\/([^[:space:]]+)\.(mp3|wma|wmv|asf|asx|mpg|mpeg)\".*\<\/a\>\]/i", "<script>doc_write(obj_movie('$1://$2.$3'));</script>", $comment);

        $cmt_sv = $cmt_amt - $i + 1; // 댓글 헤더 z-index 재설정 ie8 이하 사이드뷰 겹침 문제 해결

     ?></p>

<p>    <article id="c_<?php echo $comment_id ?>" <?php if ($cmt_depth) { ?>style="margin-left:<?php echo $cmt_depth ?>px;border-top-color:#e0e0e0"<?php } ?>>

        <header style="z-index:<?php echo $cmt_sv; ?>">

            <h1><?php echo get_text($list[$i]['wr_name']); ?>님의 댓글</h1>

            <?php if($is_admin) { ?>

                작성일

            <?php } // 관리자전용 끝 ?>

            <?php echo $list[$i]['name'] ?>

            <?php if ($cmt_depth) { ?><img src="<?php echo $board_skin_url ?>/img/icon_reply.gif" class="icon_reply" alt="댓글의 댓글"><?php } ?>

            <?php if ($is_ip_view) { ?>

            아이피

            <span class="bo_vc_hdinfo"><?php echo $list[$i]['ip']; ?></span>

            <?php } ?>

            작성일

            <span class="bo_vc_hdinfo"><time datetime="<?php echo date('Y-m-d\TH:i:s+09:00', strtotime($list[$i]['datetime'])) ?>"><?php echo $list[$i]['datetime'] ?></time></span>

            <?php

            include(G5_SNS_PATH.'/view_comment_list.sns.skin.php');

            ?>

        </header></p>

<p>        <!-- 댓글 출력 -->

        <p>

            <?php if (strstr($list[$i]['wr_option'], "secret")) { ?><img src="<?php echo $board_skin_url; ?>/img/icon_secret.gif" alt="비밀글"><?php } ?>

            <?php echo $list[$i]['wr_content'] ?>

        </p></p>

<p>        <span id="edit_<?php echo $comment_id ?>"></span><!-- 수정 -->

        <span id="reply_<?php echo $comment_id ?>"></span><!-- 답변 --></p>

<p>        <input type="hidden" value="<?php echo strstr($list[$i]['wr_option'],"secret") ?>" id="secret_comment_<?php echo $comment_id ?>">

        <input type="hidden" value="<?php echo $list[$i]['wr_datetime'] ?>" id="save_datetime_<?php echo $comment_id ?>">

        <textarea id="save_comment_<?php echo $comment_id ?>" style="display:none"><?php echo get_text($list[$i]['content1'], 0) ?></textarea></p>

<p>        <?php if($list[$i]['is_reply'] || $list[$i]['is_edit'] || $list[$i]['is_del']) {

            $query_string = clean_query_string($_SERVER['QUERY_STRING']);</p>

<p>            if($w == 'cu') {

                $sql = " select wr_id, wr_content, mb_id from $write_table where wr_id = '$c_id' and wr_is_comment = '1' ";

                $cmt = sql_fetch($sql);

                if (!($is_admin || ($member['mb_id'] == $cmt['mb_id'] && $cmt['mb_id'])))

                    $cmt['wr_content'] = '';

                $c_wr_content = $cmt['wr_content'];

            }</p>

<p>            $c_reply_href = './board.php?'.$query_string.'&amp;c_id='.$comment_id.'&amp;w=c#bo_vc_w';

            $c_edit_href = './board.php?'.$query_string.'&amp;c_id='.$comment_id.'&amp;w=cu#bo_vc_w';

         ?>

        <footer>

            <ul class="bo_vc_act">

                <?php if ($list[$i]['is_reply']) { ?><li><a href="<?php echo $c_reply_href;  ?>" onclick="comment_box('<?php echo $comment_id ?>', 'c'); return false;">답변</a></li><?php } ?>

                <?php if ($list[$i]['is_edit']) { ?><li><a href="<?php echo $c_edit_href;  ?>" onclick="comment_box('<?php echo $comment_id ?>', 'cu'); return false;">수정</a></li><?php } ?>

                <?php if ($list[$i]['is_del'])  { ?><li><a href="<?php echo $list[$i]['del_link'];  ?>" onclick="return comment_delete();">삭제</a></li><?php } ?>

            </ul>

        </footer>

        <?php } ?>

    </article>

    <?php } ?>

    <?php if ($i == 0) { //댓글이 없다면 ?><p id="bo_vc_empty">등록된 댓글이 없습니다.</p><?php } ?></p>

<p></section>

<!-- } 댓글 끝 --></p>

<p><?php if ($is_comment_write) {

    if($w == '')

        $w = 'c';

?>

<!-- 댓글 쓰기 시작 { -->

<aside id="bo_vc_w">

    <h2>댓글쓰기</h2>

    <form name="fviewcomment" action="<?php echo $comment_action_url; ?>" onsubmit="return fviewcomment_submit(this);" method="post" autocomplete="off">

    <input type="hidden" name="w" value="<?php echo $w ?>" id="w">

    <input type="hidden" name="bo_table" value="<?php echo $bo_table ?>">

    <input type="hidden" name="wr_id" value="<?php echo $wr_id ?>">

    <input type="hidden" name="comment_id" value="<?php echo $c_id ?>" id="comment_id">

    <input type="hidden" name="sca" value="<?php echo $sca ?>">

    <input type="hidden" name="sfl" value="<?php echo $sfl ?>">

    <input type="hidden" name="stx" value="<?php echo $stx ?>">

    <input type="hidden" name="spt" value="<?php echo $spt ?>">

    <input type="hidden" name="page" value="<?php echo $page ?>">

    <input type="hidden" name="is_good" value=""></p>

<p>    <div class="tbl_frm01 tbl_wrap">

        <table>

        <tbody>

        <?php if ($is_guest) { ?>

        <tr>

            <th scope="row"><label for="wr_name">이름<strong class="sound_only"> 필수</strong></label></th>

            <td><input type="text" name="wr_name" value="<?php echo get_cookie("ck_sns_name"); ?>" id="wr_name" required class="frm_input required" size="5" maxLength="20"></td>

        </tr>

        <tr>

            <th scope="row"><label for="wr_password">비밀번호<strong class="sound_only"> 필수</strong></label></th>

            <td><input type="password" name="wr_password" id="wr_password" required class="frm_input required" size="10" maxLength="20"></td>

        </tr>

        <?php } ?>

        <tr>

            <th scope="row"><label for="wr_secret">비밀글사용</label></th>

            <td><input type="checkbox" name="wr_secret" value="secret" id="wr_secret"></td>

        </tr>

        <?php if ($is_guest) { ?>

        <tr>

            <th scope="row">자동등록방지</th>

            <td><?php echo $captcha_html; ?></td>

        </tr>

        <?php } ?>

        <?php

        if($board['bo_use_sns'] && ($config['cf_facebook_appid'] || $config['cf_twitter_key'])) {

        ?>

        <tr>

            <th scope="row">SNS 동시등록</th>

            <td id="bo_vc_send_sns"></td>

        </tr>

        <?php

        }

        ?></p>

<p>        <?php if($is_admin) : ?>

        <tr>

            <th scope="row"><label for="wr_datetime">작성일<strong class="sound_only"> 필수</strong></label></th>

            <td><input type="text" name="wr_datetime" value="" id="wr_datetime" required class="frm_input required wr_datetime" size="20" maxLength="20"></td>

        </tr>

        <?php endif; ?>

        <tr>

            <th scope="row">내용</th>

            <td>

                <?php if ($comment_min || $comment_max) { ?><strong id="char_cnt"><span id="char_count"></span>글자</strong><?php } ?>

                <?php echo editor_html("wr_content", "", $is_dhtml_editor); ?>

                <?php if ($comment_min || $comment_max) { ?><script> check_byte('wr_content', 'char_count'); </script><?php } ?>

                <script>

                $(document).on("keyup change", "textarea#wr_content[maxlength]", function() {

                    var str = $(this).val()

                    var mx = parseInt($(this).attr("maxlength"))

                    if (str.length > mx) {

                        $(this).val(str.substr(0, mx));

                        return false;

                    }

                });

                </script>

            </td>

        </tr>

        </tbody>

        </table>

    </div></p>

<p>    <div class="btn_confirm">

        <input type="submit" id="btn_submit" class="btn_submit" value="댓글등록">

    </div></p>

<p>    </form>

</aside></p>

<p><script></p>

<p>var save_before = '';

var save_html = document.getElementById('bo_vc_w').innerHTML;</p>

<p>var oEditors = [];</p>

<p>function _editor() {

    nhn.husky.EZCreator.createInIFrame({

        oAppRef : oEditors,

        elPlaceHolder : "wr_content",

        sSkinURI : "/plugin/editor/smarteditor2_mobile/SmartEditor2Skin.html",    

        htParams : {

            bUseToolbar : true,                // 툴바 사용 여부 (true:사용/ false:사용하지 않음)

            bUseVerticalResizer : true,        // 입력창 크기 조절바 사용 여부 (true:사용/ false:사용하지 않음)

            bUseModeChanger : true,            // 모드 탭(Editor | HTML | TEXT) 사용 여부 (true:사용/ false:사용하지 않음)

            //aAdditionalFontList : aAdditionalFontSet,        // 추가 글꼴 목록

            fOnBeforeUnload : function(){

                //alert("완료!");

            }

        }, //boolean

        fOnAppLoad : function(){

            //예제 코드

            //oEditors.getById["ir1"].exec("PASTE_HTML", ["로딩이 완료된 후에 본문에 삽입되는 text입니다."]);

        },

        fCreator : "createSEditor2"

    });

}</p>

<p>

function good_and_write()

{

    var f = document.fviewcomment;

    if (fviewcomment_submit(f)) {

        f.is_good.value = 1;

        f.submit();

    } else {

        f.is_good.value = 0;

    }

}</p>

<p>function fviewcomment_submit(f)

{

    var pattern = /(^\s*)|(\s*$)/g; // \s 공백 문자</p>

<p>    <?php echo get_editor_js("wr_content"); ?></p>

<p>    f.is_good.value = 0;</p>

<p>    var subject = "";

    var content = "";

    $.ajax({

        url: g5_bbs_url+"/ajax.filter.php",

        type: "POST",

        data: {

            "subject": "",

            "content": f.wr_content.value

        },

        dataType: "json",

        async: false,

        cache: false,

        success: function(data, textStatus) {

            subject = data.subject;

            content = data.content;

        }

    });</p>

<p>    if (content) {

        alert("내용에 금지단어('"+content+"')가 포함되어있습니다");

        f.wr_content.focus();

        return false;

    }</p>

<p>    // 양쪽 공백 없애기

    var pattern = /(^\s*)|(\s*$)/g; // \s 공백 문자

    document.getElementById('wr_content').value = document.getElementById('wr_content').value.replace(pattern, "");

    if (char_min > 0 || char_max > 0)

    {

        check_byte('wr_content', 'char_count');

        var cnt = parseInt(document.getElementById('char_count').innerHTML);

        if (char_min > 0 && char_min > cnt)

        {

            alert("댓글은 "+char_min+"글자 이상 쓰셔야 합니다.");

            return false;

        } else if (char_max > 0 && char_max < cnt)

        {

            alert("댓글은 "+char_max+"글자 이하로 쓰셔야 합니다.");

            return false;

        }

    }

    else if (!document.getElementById('wr_content').value)

    {

        alert("댓글을 입력하여 주십시오.");

        return false;

    }</p>

<p>    if (typeof(f.wr_name) != 'undefined')

    {

        f.wr_name.value = f.wr_name.value.replace(pattern, "");

        if (f.wr_name.value == '')

        {

            alert('이름이 입력되지 않았습니다.');

            f.wr_name.focus();

            return false;

        }

    }</p>

<p>    if (typeof(f.wr_password) != 'undefined')

    {

        f.wr_password.value = f.wr_password.value.replace(pattern, "");

        if (f.wr_password.value == '')

        {

            alert('비밀번호가 입력되지 않았습니다.');

            f.wr_password.focus();

            return false;

        }

    }</p>

<p>    <?php if($is_guest) echo chk_captcha_js();  ?></p>

<p>    set_comment_token(f);</p>

<p>    document.getElementById("btn_submit").disabled = "disabled";</p>

<p>    return true;

}</p>

<p>function comment_box(comment_id, work)

{

    var el_id;

    // 댓글 아이디가 넘어오면 답변, 수정

    if (comment_id)

    {

        if (work == 'c')

            el_id = 'reply_' + comment_id;

        else

            el_id = 'edit_' + comment_id;

    }

    else

        el_id = 'bo_vc_w';</p>

<p>    if (save_before != el_id)

    {

        if (save_before)

        {

            document.getElementById(save_before).style.display = 'none';

            document.getElementById(save_before).innerHTML = '';

        }</p>

<p>        document.getElementById(el_id).style.display = '';

        document.getElementById(el_id).innerHTML = save_html;

        // 댓글 수정

        if (work == 'cu')

        {

            document.getElementById('wr_content').value = document.getElementById('save_comment_' + comment_id).value;

            document.getElementById('wr_datetime').value = document.getElementById('save_datetime_' + comment_id).value;

            if (typeof char_count != 'undefined')

                check_byte('wr_content', 'char_count');

            if (document.getElementById('secret_comment_'+comment_id).value)

                document.getElementById('wr_secret').checked = true;

            else

                document.getElementById('wr_secret').checked = false;</p>

<p>        }</p>

<p>        document.getElementById('comment_id').value = comment_id;

        document.getElementById('w').value = work;</p>

<p>        if(save_before)

            $("#captcha_reload").trigger("click");</p>

<p>        save_before = el_id;

    }</p>

<p>    if(comment_id) _editor();

}</p>

<p>function comment_delete()

{

    return confirm("이 댓글을 삭제하시겠습니까?");

}</p>

<p>comment_box('', 'c'); // 댓글 입력폼이 보이도록 처리하기위해서 추가 (root님)</p>

<p><?php if($board['bo_use_sns'] && ($config['cf_facebook_appid'] || $config['cf_twitter_key'])) { ?>

// sns 등록

$(function() {

    $("#bo_vc_send_sns").load(

        "<?php echo G5_SNS_URL; ?>/view_comment_write.sns.skin.php?bo_table=<?php echo $bo_table; ?>",

        function() {

            save_html = document.getElementById('bo_vc_w').innerHTML;

        }

    );

});

<?php } ?>

</script>

<?php } ?>

<!-- } 댓글 쓰기 끝 -->

댓글을 작성하려면 로그인이 필요합니다.

답변 1개

작업하시면서 div 닫기라던가 이런부분 지우신것 같은데 다시 채크해보세요.

로그인 후 평가할 수 있습니다

답변에 대한 댓글 1개

대전댁2
3년 전
url주소에서 다운받아서 에디터 스킨경로만 변경하고 건드린게 전혀 없어서 답변.수정.삭제 부분쪽에 소스가 빠진것 같아서 아무리 만져 봐도 아닌것 같고 제가 보기에는 테마스킨 하고 무슨 간섭이 있는게 아닐까 생각이 드네요.

(변경전) sSkinURI : "/plugin/editor/smarteditor/SmartEditor2Skin.html",
(변경후) sSkinURI : "/plugin/editor/smarteditor2_mobile/SmartEditor2Skin.html",

[code]
function _editor() {
nhn.husky.EZCreator.createInIFrame({
oAppRef : oEditors,
elPlaceHolder : "wr_content",
sSkinURI : "/plugin/editor/smarteditor2_mobile/SmartEditor2Skin.html",
htParams : {
bUseToolbar : true, // 툴바 사용 여부 (true:사용/ false:사용하지 않음)
bUseVerticalResizer : true, // 입력창 크기 조절바 사용 여부 (true:사용/ false:사용하지 않음)
bUseModeChanger : true, // 모드 탭(Editor | HTML | TEXT) 사용 여부 (true:사용/ false:사용하지 않음)
//aAdditionalFontList : aAdditionalFontSet, // 추가 글꼴 목록
fOnBeforeUnload : function(){
//alert("완료!");
[/code]

댓글을 작성하려면 로그인이 필요합니다.

답변을 작성하려면 로그인이 필요합니다.

로그인