/** * 商品参数数据创建 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2020-09-02 * @desc description * @param {[int]} type [展示类型(0,1,2)] * @param {[string]} name [参数名称] * @param {[string]} value [参数值] */ function ParametersItemHtmlCreated(type, name, value) { var index = parseInt(Math.random()*1000001); var html = ''; html += ''; html += ''; html += ''; html += ''; html += ''; html += ''; html += ''; html += ''; html += ''; html += ''; html += '上移'; html += '下移'; html += '移除'; html += ''; // 数据添加 var $parameters_table = $('.parameters-table'); $parameters_table.append(html); // select组件初始化 $parameters_table.find('.parameters-line-'+index+' .chosen-select').chosen({ inherit_select_classes: true, enable_split_word_search: true, search_contains: true, no_results_text: '没有匹配到结果' }); } /** * 动态数据表格高度处理 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2020-11-29 * @desc description */ function FormTableHeightHandle() { // 表格内容 if($('.am-table-scrollable-horizontal').length > 0) { // 页面右侧总内容容器高度 var height = $('.content-right .content-top').outerHeight(true) || 0; $('.content-right').css('height', 'calc(100% - '+height+'px)'); // 内容高度 var height_top = $('.form-table-operate-top').outerHeight(true) || 0; var height_bottom = $('.form-table-operate-bottom').outerHeight(true) || 0; $('.am-table-scrollable-horizontal').css('max-height', 'calc(100% - '+(height_top+height_bottom)+'px)'); } // 表格内容外围高度 if($('.form-validation-search').length > 0) { var height = $('.form-table-content .am-pagination').outerHeight(true) || 0; $('.form-validation-search').css('height', 'calc(100% - '+height+'px)'); } } $(function() { // 商品参数添加 var $parameters_table = $('.parameters-table'); $('.parameters-line-add').on('click', function() { // 追加内容 ParametersItemHtmlCreated(); }); // 商品参数移动 $parameters_table.on('click', '.line-move', function() { // 类型 var type = $(this).data('type') || null; if(type == null) { Prompt('操作类型配置有误'); return false; } // 索引 var count = $parameters_table.find('tbody tr').length; var index = $(this).parents('tr').index() || 0; var $parent = $(this).parents('tr'); switch(type) { // 上移 case 'top' : if(index == 0) { Prompt('已到最顶部'); return false; } $parent.prev().insertAfter($parent); break; // 下移 case 'bottom' : if(index >= count-1) { Prompt('已到最底部'); return false; } $parent.next().insertBefore($parent); break; // 默认 default : Prompt('操作类型配置有误'); } }); // 商品参数移除 $parameters_table.on('click', '.line-remove', function() { $(this).parents('tr').remove(); }); // 商品参数配置信息复制 var $parameters_copy_modal = $('#parameters-quick-copy-modal'); var clipboard = new ClipboardJS('.parameters-quick-copy', { text: function() { // 获取商品参数配置信息 var data = []; $parameters_table.find('tbody tr').each(function(k, v) { data.push({ "type": $(this).find('td:eq(0) select').val(), "name": $(this).find('td:eq(1) input').val(), "value": $(this).find('td:eq(2) input').val(), }); }); data = JSON.stringify(data); $parameters_copy_modal.find('textarea').val(data); return data; } }); clipboard.on('success', function(e) { Prompt('复制成功', 'success'); }); clipboard.on('error', function(e) { // 复制失败则开启复制窗口,让用户自己复制 $parameters_copy_modal.modal({ width: 200, height: 135 }); }); // 点击选中复制的值 $parameters_copy_modal.find('textarea').on('click', function() { $(this).select(); }); // 商品参数快捷操作 var $parameters_quick_config = $('.parameters-quick-config'); $parameters_quick_config.find('button').on('click', function() { // 配置数据 var data = $parameters_quick_config.find('textarea').val() || null; if(data == null) { Prompt('请先粘贴配置信息'); return false; } // 异常处理、防止json格式错误 try { data = JSON.parse(data); } catch(e) { Prompt('配置格式错误'); return false; } if(data.length <= 0) { Prompt('配置为空'); return false; } // 数据生成 $parameters_table.find('tbody').html(''); for(var i in data) { var type = (data[i]['type'] == undefined) ? 1 : data[i]['type']; var name = data[i]['name'] || ''; var value = data[i]['value'] || ''; ParametersItemHtmlCreated(type, name, value); } $('#parameters-quick-container').dropdown('close'); Prompt('生成成功', 'success'); }); // 商品参数清空 $('.parameters-quick-remove').on('click', function() { $parameters_table.find('tbody').html(''); }); // 浏览器窗口实时事件 $(window).resize(function() { // 动态数据表格高度处理 FormTableHeightHandle(); }); // 动态数据表格高度处理 FormTableHeightHandle(); });