|  |  |  | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="layui-row layui-col-space10 layui-form-item"> | 
|---|
|  |  |  | <div class="layui-form-item"> | 
|---|
|  |  |  | <div class="layui-col-lg6"> | 
|---|
|  |  |  | <label class="layui-form-label febs-form-item-require">商品分类:</label> | 
|---|
|  |  |  | <div class="layui-input-block"> | 
|---|
|  |  |  | <!--                                                    <select name="categoryId" class="categary-addPeoduct">--> | 
|---|
|  |  |  | <!--                                                        <option value="">请选择</option>--> | 
|---|
|  |  |  | <!--                                                    </select>--> | 
|---|
|  |  |  | <div id="goods-category"></div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="layui-col-lg6"> | 
|---|
|  |  |  | <label class="layui-form-label">是否主推:</label> | 
|---|
|  |  |  | <div class="layui-input-block"> | 
|---|
|  |  |  | <input type="radio" name="isHot" value="1" title="是"  /> | 
|---|
|  |  |  | <input type="radio" name="isHot" value="2" title="否"  checked /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="layui-form-item"> | 
|---|
|  |  |  | <div class="layui-col-lg6"> | 
|---|
|  |  |  | <label class="layui-form-label febs-form-item-require">排序:</label> | 
|---|
|  |  |  | <div class="layui-input-block"> | 
|---|
|  |  |  | <input type="text" name="sortCnt"  lay-verify="required|integer" placeholder="" autocomplete="off" class="layui-input"> | 
|---|
|  |  |  | <div class="layui-form-mid layui-word-aux">设置商品排序位置,想排列在前,设置的数字越小</div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="layui-col-lg6"> | 
|---|
|  |  |  | <label class="layui-form-label febs-form-item-require">抵扣现金(%):</label> | 
|---|
|  |  |  | <div class="layui-input-block"> | 
|---|
|  |  |  | <input type="text" name="scorePercent"  lay-verify="required" placeholder="" autocomplete="off" class="layui-input"> | 
|---|
|  |  |  | <div class="layui-word-aux">设置50,即商品价格1000,积分可抵扣的最大金额为1000*50%=500,填写整数,如【50】</div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="layui-form-item"> | 
|---|
|  |  |  | <label class="layui-form-label">商品介绍:</label> | 
|---|
|  |  |  | <div class="layui-input-block"> | 
|---|
|  |  |  | <label> | 
|---|
|  |  |  | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <blockquote class="layui-elem-quote blue-border">商品类型</blockquote> | 
|---|
|  |  |  | <blockquote class="layui-elem-quote blue-border">商品类型:</blockquote> | 
|---|
|  |  |  | <div class="layui-form-item"> | 
|---|
|  |  |  | <label class="layui-form-label febs-form-item-require">商品类型</label> | 
|---|
|  |  |  | <div class="layui-input-block"> | 
|---|
|  |  |  | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="layui-form-item febs-hide tc-set"> | 
|---|
|  |  |  | <label class="layui-form-label">静态倍数</label> | 
|---|
|  |  |  | <label class="layui-form-label">贡献值:</label> | 
|---|
|  |  |  | <div class="layui-input-block"> | 
|---|
|  |  |  | <input type="text" name="staticMulti" placeholder="请输入静态倍数" | 
|---|
|  |  |  | autoComplete="off" class="layui-input"> | 
|---|
|  |  |  | <div class="layui-form-mid layui-word-aux">支付后,赠送(购买金额*静态倍数)的赠送积分 | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <input type="text" name="star" lay-verify="required"  placeholder="请输入贡献值" autocomplete="off" class="layui-input"> | 
|---|
|  |  |  | <div class="layui-form-mid layui-word-aux">支付后,用户获取对应的贡献值</div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <!--                                        <div class="layui-form-item febs-hide tc-set">--> | 
|---|
|  |  |  | <!--                                            <label class="layui-form-label">静态倍数</label>--> | 
|---|
|  |  |  | <!--                                            <div class="layui-input-block">--> | 
|---|
|  |  |  | <!--                                                <input type="text" name="staticMulti" placeholder="请输入静态倍数"--> | 
|---|
|  |  |  | <!--                                                       autoComplete="off" class="layui-input">--> | 
|---|
|  |  |  | <!--                                                <div class="layui-form-mid layui-word-aux">支付后,赠送(购买金额*静态倍数)的赠送积分--> | 
|---|
|  |  |  | <!--                                                </div>--> | 
|---|
|  |  |  | <!--                                            </div>--> | 
|---|
|  |  |  | <!--                                        </div>--> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="layui-form-item febs-hide tc-set"> | 
|---|
|  |  |  | <label class="layui-form-label">静态占比(%)</label> | 
|---|
|  |  |  | <div class="layui-input-block"> | 
|---|
|  |  |  | <input type="text" name="staticProp" placeholder="请输入静态占比" | 
|---|
|  |  |  | autoComplete="off" class="layui-input"> | 
|---|
|  |  |  | <div class="layui-form-mid layui-word-aux">所有套餐静态占比相加应等于100%</div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <!--                                        <div class="layui-form-item febs-hide tc-set">--> | 
|---|
|  |  |  | <!--                                            <label class="layui-form-label">静态占比(%)</label>--> | 
|---|
|  |  |  | <!--                                            <div class="layui-input-block">--> | 
|---|
|  |  |  | <!--                                                <input type="text" name="staticProp" placeholder="请输入静态占比"--> | 
|---|
|  |  |  | <!--                                                       autoComplete="off" class="layui-input">--> | 
|---|
|  |  |  | <!--                                                <div class="layui-form-mid layui-word-aux">所有套餐静态占比相加应等于100%</div>--> | 
|---|
|  |  |  | <!--                                            </div>--> | 
|---|
|  |  |  | <!--                                        </div>--> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="layui-tab-item"> | 
|---|
|  |  |  | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="layui-form-item"> | 
|---|
|  |  |  | <label class="layui-form-label">商品参数:</label> | 
|---|
|  |  |  | <div class="layui-input-block"> | 
|---|
|  |  |  | <label> | 
|---|
|  |  |  | <textarea name="goodsParameter" rows="5" autoComplete="off" | 
|---|
|  |  |  | class="layui-textarea"></textarea> | 
|---|
|  |  |  | </label> | 
|---|
|  |  |  | </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" lay-verify="goodsDetails" name="goodsDetails" class="layui-textarea"></textarea>–>--> | 
|---|
|  |  |  | <!--                                                <div style="border: 1px solid #ccc;">--> | 
|---|
|  |  |  | <!--                                                    <div id="toolbar-container" style="border-bottom: 1px solid #ccc;"></div>--> | 
|---|
|  |  |  | <!--                                                    <div id="editor-container" style="height: 300px;"></div>--> | 
|---|
|  |  |  | <!--                                                </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" lay-verify="goodsDetails" name="goodsDetails" class="layui-textarea"></textarea>--> | 
|---|
|  |  |  | <!--                                                <textarea id="goodsDetailEditAdd" lay-verify="content" name = "goodsDetails" class="layui-textarea"></textarea>--> | 
|---|
|  |  |  | <div style="border: 1px solid #ccc;"> | 
|---|
|  |  |  | <div id="toolbar-container" style="border-bottom: 1px solid #ccc;"></div> | 
|---|
|  |  |  | <div id="editor-container" style="height: 300px;"></div> | 
|---|
|  |  |  | <div id="toolbar-container" class="toolbar"></div> | 
|---|
|  |  |  | <div id="text-container" class="text" style="height: 450px;"></div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | formSelects.render(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var E = window.wangEditor; | 
|---|
|  |  |  | const editorConfig = { MENU_CONF: {} }; | 
|---|
|  |  |  | editorConfig.MENU_CONF['uploadImage'] = { | 
|---|
|  |  |  | server: '/admin/goods/uploadFileBase64', | 
|---|
|  |  |  | fieldName : "file", | 
|---|
|  |  |  | customInsert(res, insertFn) { | 
|---|
|  |  |  | insertFn(res.data.src, res.data.title, '') | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | } | 
|---|
|  |  |  | form.verify({ | 
|---|
|  |  |  | integer: [ | 
|---|
|  |  |  | /^[1-9]\d*$/ | 
|---|
|  |  |  | , '只能输入正整数' | 
|---|
|  |  |  | ] | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // var E = window.wangEditor; | 
|---|
|  |  |  | // const editorConfig = { MENU_CONF: {} }; | 
|---|
|  |  |  | // editorConfig.MENU_CONF['uploadImage'] = { | 
|---|
|  |  |  | //     server: '/admin/goods/uploadFileBase64', | 
|---|
|  |  |  | //     fieldName : "file", | 
|---|
|  |  |  | //     customInsert(res, insertFn) { | 
|---|
|  |  |  | //         insertFn(res.data.src, res.data.title, '') | 
|---|
|  |  |  | //     }, | 
|---|
|  |  |  | // } | 
|---|
|  |  |  | const E = window.wangEditor; | 
|---|
|  |  |  | const editor = new E('#toolbar-container', '#text-container'); // 传入两个元素 | 
|---|
|  |  |  | editor.config.showLinkImg = false; | 
|---|
|  |  |  | editor.config.uploadFileName = 'file'; | 
|---|
|  |  |  | editor.config.customUploadImg = function (files, insertImgFn) { | 
|---|
|  |  |  | // files 是 input 中选中的文件列表 | 
|---|
|  |  |  | // insertImgFn 是获取图片 url 后,插入到编辑器的方法 | 
|---|
|  |  |  | // 上传图片,返回结果,将图片插入到编辑器中 | 
|---|
|  |  |  | for (let i = 0; i < files.length; i++){ | 
|---|
|  |  |  | var form = new FormData(); | 
|---|
|  |  |  | form.append("file", files[0]); | 
|---|
|  |  |  | $.ajax({ | 
|---|
|  |  |  | url:'/admin/goods/uploadFileBase64', | 
|---|
|  |  |  | type: "post", | 
|---|
|  |  |  | processData: false, | 
|---|
|  |  |  | contentType: false, | 
|---|
|  |  |  | data: form, | 
|---|
|  |  |  | dataType: 'json', | 
|---|
|  |  |  | success(res) { | 
|---|
|  |  |  | // 上传代码返回结果之后,将图片插入到编辑器中 | 
|---|
|  |  |  | insertImgFn(res.data.src, res.data.title, '') | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | editor.create(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var category = xmSelect.render({ | 
|---|
|  |  |  | el: '#goods-category', | 
|---|
|  |  |  | 
|---|
|  |  |  | "unit": goodsInfo.unit, | 
|---|
|  |  |  | "stock": goodsInfo.stock, | 
|---|
|  |  |  | "volume": goodsInfo.volume, | 
|---|
|  |  |  | "isHot": goodsInfo.isHot, | 
|---|
|  |  |  | "goodsParameter": goodsInfo.goodsParameter, | 
|---|
|  |  |  | "goodsIntrodution": goodsInfo.goodsIntrodution, | 
|---|
|  |  |  | "isNormal": goodsInfo.isNormal, | 
|---|
|  |  |  | "staticMulti": goodsInfo.staticMulti, | 
|---|
|  |  |  | 
|---|
|  |  |  | "presentPrice": goodsInfo.presentPrice, | 
|---|
|  |  |  | "costPrice": goodsInfo.costPrice, | 
|---|
|  |  |  | "isSku": goodsInfo.isSku, | 
|---|
|  |  |  | "hasCarriage": goodsInfo.hasCarriage, | 
|---|
|  |  |  | "carriage": goodsInfo.carriage, | 
|---|
|  |  |  | "thumb": goodsInfo.thumb, | 
|---|
|  |  |  | "star": goodsInfo.star, | 
|---|
|  |  |  | "sortCnt": goodsInfo.sortCnt, | 
|---|
|  |  |  | "scorePercent": goodsInfo.scorePercent, | 
|---|
|  |  |  | "goodsDetails": goodsInfo.goodsDetails, | 
|---|
|  |  |  | "thumbs": thumbs | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (goodsInfo.isNormal == 2) { | 
|---|
|  |  |  | $(".tc-set").show(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (goodsInfo.hasCarriage == 1) { | 
|---|
|  |  |  | $(".carriage-input").show(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (goodsInfo.isSku == 1) { | 
|---|
|  |  |  | 
|---|
|  |  |  | imgSingleBind(); | 
|---|
|  |  |  | imgMultiBind(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | window.editor = E.createEditor({ | 
|---|
|  |  |  | html: goodsInfo.goodsDetails, | 
|---|
|  |  |  | selector: '#editor-container', | 
|---|
|  |  |  | config : editorConfig, | 
|---|
|  |  |  | mode: 'default' | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | window.toolbar = E.createToolbar({ | 
|---|
|  |  |  | editor, | 
|---|
|  |  |  | selector: '#toolbar-container', | 
|---|
|  |  |  | mode: 'default' | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // window.editor = E.createEditor({ | 
|---|
|  |  |  | //     html: goodsInfo.goodsDetails, | 
|---|
|  |  |  | //     selector: '#editor-container', | 
|---|
|  |  |  | //     config : editorConfig, | 
|---|
|  |  |  | //     mode: 'default' | 
|---|
|  |  |  | // }); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | // window.toolbar = E.createToolbar({ | 
|---|
|  |  |  | //     editor, | 
|---|
|  |  |  | //     selector: '#toolbar-container', | 
|---|
|  |  |  | //     mode: 'default' | 
|---|
|  |  |  | // }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (skus) { | 
|---|
|  |  |  | tableSkuData = skus; | 
|---|
|  |  |  | reloadTable(skus); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | editor.txt.html(goodsInfo.goodsDetails); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | form.on('submit(goods-update-form-submit)', function (data) { | 
|---|
|  |  |  | 
|---|
|  |  |  | data.field.mailGoodsSkuDto = tableSkuData; | 
|---|
|  |  |  | data.field.delSkuId=delSku; | 
|---|
|  |  |  | data.field.categoryId = category.getValue('valueStr'); | 
|---|
|  |  |  | data.field.goodsDetails = editor.getHtml(); | 
|---|
|  |  |  | // data.field.goodsDetails = editor.getHtml(); | 
|---|
|  |  |  | data.field.goodsDetails = editor.txt.html(); | 
|---|
|  |  |  | $.ajax({ | 
|---|
|  |  |  | 'url': ctx + 'admin/goods/updateMallGoods', | 
|---|
|  |  |  | 'type': 'post', | 
|---|