Administrator
2025-05-08 d4f038804739521706071880fd4be38f485f97e4
src/main/resources/templates/febs/views/modules/news/newsInfoUpdate.html
@@ -31,29 +31,45 @@
        <div class="layui-form-item">
            <label class="layui-form-label febs-form-item-require">标题:</label>
            <div class="layui-input-block">
                <input type="text" name="title" lay-verify="required" autocomplete="off" class="layui-input" >
                <input type="text" name="title" autocomplete="off" class="layui-input" >
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label febs-form-item-require">内容:</label>
            <label class="layui-form-label febs-form-item-require">分类:</label>
            <div class="layui-input-block">
                <input type="text" name="content" lay-verify="required" autocomplete="off" class="layui-input" >
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label febs-form-item-require">类型:</label>
            <div class="layui-input-block">
                <input type="radio" name="type" value="1" title="文章" checked="">
                <input type="radio" name="type" value="2" title="跳转到产品">
                <select name="categoryId" class="news-category" id="news-category" >
                    <option value="">请选择</option>
                </select>
            </div>
        </div>
        <div class="layui-col-lg6">
            <label class="layui-form-label">绑定产品:</label>
        <div class="layui-form-item">
            <label class="layui-form-label">视频:</label>
            <div class="layui-input-block">
                <select name="goodsId" class="newsInfo-update-goods" id="goodsSelectUpdate" >
                    <option value="">请选择</option>
                </select>
                <button type="button" class="layui-btn upload" id="upload" style="background-color: #009688; margin-bottom: 2px">上传文件</button>
                <button type="button" class="layui-btn layui-btn-danger" id="uploadDel" style="margin-bottom: 2px">删除</button>
                <input type="text" name="videoUrl" autocomplete="off" value="" id="videoUrl" class="layui-input" readonly>
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">缩略图:</label>
            <div class="layui-input-block">
                <button type="button" class="layui-btn" id="imageUpload" style="background-color: #009688; margin-bottom: 2px">图片上传</button>
                <blockquote class="layui-elem-quote layui-quote-nm" style="margin-top: 10px;">
                    <div class="layui-upload-list" id="thumbImage"></div>
                </blockquote>
                <div class="layui-word-aux">双击图片删除</div>
                <div class="febs-hide">
                    <input type="text" id="thumb"  name="thumb" autocomplete="off" class="layui-input" readonly>
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label febs-form-item-require">内容:</label>
            <div class="layui-input-block">
                <textarea id="lay_edit" name = "content" lay-verify="content" class="layui-textarea"></textarea>
            </div>
        </div>
        <div class="layui-form-item febs-hide">
@@ -63,30 +79,32 @@
</div>
<script data-th-inline="javascript">
    layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree', 'laydate'], function () {
    layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree','layedit', 'laydate', 'upload'], function () {
        var $ = layui.$,
            febs = layui.febs,
            layer = layui.layer,
            upload = layui.upload,
            formSelects = layui.formSelects,
            treeSelect = layui.treeSelect,
            form = layui.form,
            laydate = layui.laydate,
            eleTree = layui.eleTree,
            layedit = layui.layedit,
            newsInfo = [[${newsInfo}]],
            $view = $('#newsInfo-update'),
            $uploadDel = $view.find('#uploadDel'),
            validate = layui.validate;
        //(下拉框)
        $.get(ctx + 'admin/goods/goods/allTree', function (data) {
            for (var k in data)
            {
                $(".newsInfo-update-goods").append("<option value='" + data[k].goodsId + "'>" + data[k].goodsName + "</option>");
        $.get(ctx + 'admin/news/findAllCategoryList', function (data) {
            var arr = data.data;
            for (let i = 0; i < arr.length; i++) {
                $(".news-category").append("<option value='" + arr[i].id + "'>" + arr[i].title + "</option>");
            }
            layui.use('form', function () {
                var form = layui.form;
                $("#goodsSelectUpdate").val(newsInfo.targetId)
                form.render();
            });
            initUserValue();
        });
        form.render();
@@ -94,21 +112,26 @@
            elem: '#febs-form-group-date'
        });
        layedit.set({   //设置图片接口
            uploadImage: {
                url: 'admin/goods/uploadFileBase64', //接口url
                type: 'post',
            }
        });
        //创建一个编辑器
        var index = layedit.build('lay_edit',{
            height: 300
        });
        form.verify({
            //content富文本域中的lay-verify值
            content: function(value) {
                return layedit.sync(index);
            }
        });
        formSelects.render();
        initUserValue();
        function initUserValue() {
            form.val("newsInfo-update-form", {
                "id": newsInfo.id,
                "targetId": newsInfo.targetId,
                "title": newsInfo.title,
                "content": newsInfo.content,
                "type": newsInfo.type
            });
        }
        form.on('submit(newsInfo-update-form-submit)', function (data) {
            febs.post(ctx + 'admin/news/updateNewsInfo', data.field, function () {
                layer.closeAll();
@@ -117,5 +140,94 @@
            });
            return false;
        });
        upload.render({
            elem: '#imageUpload'
            ,url: ctx + 'admin/goods/uploadFileBase64' //改成您自己的上传接口
            ,multiple: false
            ,before: function(obj){
                //预读本地文件示例,不支持ie8
                obj.preview(function(index, file, result){
                    if ($("#thumb").val()) {
                        $('#thumbImage').html('<img src="'+ result +'" alt="'+ file.name +'" class="layui-upload-img new-image" style="width: 130px">')
                    } else {
                        $('#thumbImage').append('<img src="'+ result +'" alt="'+ file.name +'" class="layui-upload-img new-image" style="width: 130px">')
                    }
                    // $('#thumbImage').html('<img src="'+ result +'" alt="'+ file.name +'" class="layui-upload-img new-image" style="width: 100px">')
                });
            }
            ,done: function(res){
                $("#thumb").val(res.data.src);
                imgUnBind(".new-image");
                imgSingleBind();
            }
        });
        function imgUnBind(className) {
            $(className).each(function() {
                $(this).unbind('dblclick');
            })
        }
        function imgSingleBind() {
            $(".new-image").each(function(index, element) {
                $(this).on("dblclick", function() {
                    var imgThumb = $(".new-image")[index];
                    $(imgThumb).remove();
                    $("#thumb").val("");
                    imgUnBind(".new-image");
                    imgSingleBind();
                });
            })
        }
        $uploadDel.on('click', function () {
            $("#videoUrl").val('');
        });
        bindUpload();
        function bindUpload() {
            upload.render({
                elem: '.upload'
                ,url: ctx + 'admin/goods/uploadFileBase64' //改成您自己的上传接口
                ,accept: 'file'
                ,before: function(obj){
                    layer.msg('上传中', {icon: 16, time: 0});
                }
                ,done: function(res){
                    var item = this.item;
                    //如果上传失败
                    if(res.code !== 0){
                        return layer.msg('上传失败');
                    }
                    // $(item).parent().prev().find('input').val(res.data[0]);
                    $("#videoUrl").val(res.data.src);
                    layer.msg('上传完毕', {icon: 1});
                }
                ,error: function(err){
                    return layer.msg('上传失败');
                }
            });
        }
        function initUserValue() {
            var thumb = newsInfo.thumb;
            $('#thumbImage').html('<img src="' + thumb + '" alt="" class="layui-upload-img new-image" style="width: 100px">')
            form.val("newsInfo-update-form", {
                "id": newsInfo.id,
                "categoryId": newsInfo.categoryId,
                "title": newsInfo.title,
                "videoUrl": newsInfo.videoUrl,
                "thumb": newsInfo.thumb,
                "content": newsInfo.content,
            });
            imgSingleBind();
            layedit.setContent(index, newsInfo.content, false);
        }
    });
</script>