vr-shopxo-source/public/static/admin/default/js/goods.js

547 lines
21 KiB
JavaScript
Raw Normal View History

2019-09-21 16:35:17 +00:00
/**
* 笛卡尔积生成规格
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @datetime 2019-09-22T00:33:48+0800
* @desc description
* @param {[array]} arr1 [要进行笛卡尔积的二维数组]
* @param {[array]} arr2 [最终实现的笛卡尔积组合,可不写]
*/
2019-09-22 02:07:33 +00:00
function SpecCartesian(arr1, arr2)
2019-09-21 16:35:17 +00:00
{
// 去除第一个元素
var result = [];
var temp_arr = arr1;
var first = temp_arr.splice(0, 1);
if((arr2 || null) == null)
{
arr2 = [];
}
// 判断是否是第一次进行拼接
if(arr2.length > 0)
{
for(var i in arr2)
{
for(var k in first[0].value)
{
result.push(arr2[i]+','+first[0].value[k]);
}
}
} else {
for(var i in first[0].value)
{
result.push(first[0].value[i]);
}
}
// 递归进行拼接
if(arr1.length > 0)
{
2019-09-22 02:07:33 +00:00
result = SpecCartesian(arr1, result);
2019-09-21 16:35:17 +00:00
}
// 返回最终笛卡尔积
return result;
}
2018-12-28 10:58:37 +00:00
$(function()
{
2019-07-21 15:51:47 +00:00
// 表单初始化
FromInit('form.form-validation-specifications-extends');
2018-12-28 10:58:37 +00:00
// 商品导航
$('.goods-nav li a').on('click', function()
{
$('.goods-nav li a').removeClass('goods-nav-active');
$(this).addClass('goods-nav-active');
2019-09-11 13:06:04 +00:00
});
// 商品导航收缩
$('.goods-nav li.nav-shrink-submit').on('click', function()
{
if($(this).find('i').hasClass('am-icon-angle-double-right'))
{
$(this).find('i').removeClass('am-icon-angle-double-right');
$(this).find('i').addClass('am-icon-angle-double-left');
$(this).parents('.goods-nav').addClass('goods-nav-retract');
$('.goods-nav-retract').animate({right:'-110px'}, 500, function()
{
$('.goods-nav-retract li.nav-shrink-submit').animate({width: '50px', left:'-51px'});
});
} else {
$(this).find('i').removeClass('am-icon-angle-double-left');
$(this).find('i').addClass('am-icon-angle-double-right');
$(this).parents('.goods-nav').removeClass('goods-nav-retract');
$('.goods-nav').animate({right:'-0px'});
$('.goods-nav li.nav-shrink-submit').animate({width: '100%', left:'0px'});
}
});
2018-12-28 10:58:37 +00:00
// 规格列添加
$('.specifications-nav-title-add').on('click', function()
{
var spec_max = $('#goods-nav-operations').data('spec-add-max-number') || 3;
if($('.specifications-table th.table-title').length >= spec_max)
{
Prompt('最多添加'+spec_max+'列规格');
return false;
}
// title
var index = parseInt(Math.random()*1000001);
html = '<th class="table-title table-title-'+index+'">';
html += '<i class="am-close am-close-spin title-nav-remove" data-index="'+index+'">&times;</i>';
html += '<input type="text" name="specifications_name_'+index+'" placeholder="规格名" class="am-radius" data-validation-message="请填写规格名" required />';
html += '</th>';
$('.title-start').before(html);
// value
html = '<td class="table-value table-value-'+index+'">';
html += '<input type="text" name="specifications_value_'+index+'[]" placeholder="规格值" class="am-radius" data-validation-message="请填写规格值" required />';
html += '</td>';
$('.value-start').before(html);
});
// 规格列移除
$(document).on('click', '.specifications-table .title-nav-remove', function()
{
var index = $(this).data('index');
$('.table-title-'+index).remove();
$('.table-value-'+index).remove();
if($('.specifications-table th.table-title').length <= 0)
{
$('.specifications-table tr.line-not-first').remove();
}
});
// 添加一行规格值
$('.specifications-line-add').on('click', function()
{
if($('.specifications-table th.table-title').length <= 0)
{
Prompt('请先添加规格');
return false;
}
2019-07-21 15:51:47 +00:00
var index = parseInt(Math.random()*1000001);
2018-12-28 10:58:37 +00:00
var html = $('.specifications-table').find('tbody tr:last').prop('outerHTML');
if(html.indexOf('<!--operation-->') >= 0)
{
html = html.replace(/<!--operation-->/ig, '<span class="fs-12 cr-blue c-p m-r-5 line-copy">复制</span> <span class="fs-12 cr-red c-p line-remove">移除</span>');
}
$('.specifications-table').append(html);
2019-07-21 15:51:47 +00:00
$('.specifications-table').find('tbody tr:last').attr('class', 'line-'+index+' line-not-first');
$('.specifications-table').find('tbody tr:last').attr('data-line-tag', '.line-'+index);
2018-12-28 10:58:37 +00:00
// 值赋空
$('.specifications-table').find('tbody tr:last').find('input').each(function(k, v)
{
$(this).attr('value', '');
});
});
// 规格行复制
$(document).on('click', '.specifications-table .line-copy', function()
{
2019-07-21 15:51:47 +00:00
var index = parseInt(Math.random()*1000001);
2018-12-28 10:58:37 +00:00
var $parent = $(this).parents('tr');
$parent.find('input').each(function(k, v)
{
$(this).attr('value', $(this).val());
});
$parent.after($parent.prop('outerHTML'));
2019-07-21 15:51:47 +00:00
$('.specifications-table').find('tbody tr:last').attr('class', 'line-'+index+' line-not-first');
$('.specifications-table').find('tbody tr:last').attr('data-line-tag', '.line-'+index);
2018-12-28 10:58:37 +00:00
});
// 规格行移除
$(document).on('click', '.specifications-table .line-remove', function()
{
$(this).parents('tr').remove();
if($('.specifications-table tbody tr').length <= 1)
{
$('.specifications-table th.table-title').remove();
$('.specifications-table td.table-value').remove();
$('ul.spec-images-list').html('');
}
});
// 添加规格图片
$('.specifications-line-images-add').on('click', function()
{
2019-09-23 09:30:05 +00:00
// 是否存在规格
2018-12-28 10:58:37 +00:00
if($('.specifications-table th.table-title').length <= 0)
{
Prompt('请先添加规格');
return false;
}
// 开始添加
var index = parseInt(Math.random()*1000001);
var temp_class = 'spec-images-items-'+index;
var html = '<li class="spec-images-items '+temp_class+'">';
html += '<input type="text" name="spec_images_name['+index+']" placeholder="规格名称" class="am-radius t-c" data-validation-message="请填写规格名称" required />'
html += '<ul class="plug-file-upload-view spec-images-view-'+index+'" data-form-name="spec_images['+index+']" data-max-number="1" data-dialog-type="images">';
html += '<li>';
html += '<input type="text" name="spec_images['+index+']" data-validation-message="请上传规格图片" required />';
2019-04-18 17:15:30 +00:00
html += '<img src="'+__attachment_host__+'/static/admin/default/images/default-images.jpg" />';
2018-12-28 10:58:37 +00:00
html += '<i>×</i>';
html += '</li>';
html += '</ul>';
html += '<div class="plug-file-upload-submit" data-view-tag="ul.spec-images-view-'+index+'">+上传图片</div>';
html += '</li>';
$('ul.spec-images-list').append(html);
});
// 规格图片删除
$('ul.spec-images-list').on('click', 'ul.plug-file-upload-view li i', function()
{
$(this).parents('li.spec-images-items').remove();
});
2019-09-23 09:30:05 +00:00
// 规格图片自动添加
$('.specifications-line-images-auto-add').on('click', function()
{
// 是否存在规格
var spec_count = $('.specifications-table th.table-title').length || 0;
if(spec_count <= 0)
{
Prompt('请先添加规格');
return false;
}
// 获取第一列规格名称
var data = [];
var index = parseInt($(this).find('input').val()) || 1;
if(index <= 0)
{
index = 1;
}
if(index > spec_count)
{
index = spec_count;
}
index -= 1;
$('.specifications-table tbody tr').each(function(k, v)
{
var value = $(this).find('td').eq(index).find('input').val() || null;
if(value != null && data.indexOf(value) == -1)
{
data.push(value);
}
});
// 创建图片规格
if(data.length > 0)
{
// 获取已存在规格图片
var data_old = [];
$('ul.spec-images-list li.spec-images-items').each(function(k, v)
{
var value = $(this).find('input').val() || null;
2019-09-23 10:30:59 +00:00
if(value == null)
{
$(this).remove();
} else if(data_old.indexOf(value) == -1)
2019-09-23 09:30:05 +00:00
{
data_old.push(value);
}
});
// 循环添加
for(var i in data)
{
// 开始添加,不存在则不添加
if(data_old.indexOf(data[i]) == -1)
{
var index = parseInt(Math.random()*1000001);
var temp_class = 'spec-images-items-'+index;
var html = '<li class="spec-images-items '+temp_class+'">';
html += '<input type="text" name="spec_images_name['+index+']" value="'+data[i]+'" placeholder="规格名称" class="am-radius t-c" data-validation-message="请填写规格名称" required />'
html += '<ul class="plug-file-upload-view spec-images-view-'+index+'" data-form-name="spec_images['+index+']" data-max-number="1" data-dialog-type="images">';
html += '<li>';
html += '<input type="text" name="spec_images['+index+']" data-validation-message="请上传规格图片" required />';
html += '<img src="'+__attachment_host__+'/static/admin/default/images/default-images.jpg" />';
html += '<i>×</i>';
html += '</li>';
html += '</ul>';
html += '<div class="plug-file-upload-submit" data-view-tag="ul.spec-images-view-'+index+'">+上传图片</div>';
html += '</li>';
$('ul.spec-images-list').append(html);
}
}
// 原始图片规格不存在指定规格列中则移除
for(var i in data_old)
{
if(data.indexOf(data_old[i]) == -1)
{
$('ul.spec-images-list li.spec-images-items').each(function(k, v)
{
var value = $(this).find('input').val() || null;
if(value == data_old[i])
{
$(this).remove();
}
});
}
}
}
});
// 自动添加图片规格input输入值处理
$('.specifications-line-images-auto-add input').on('blur', function()
{
var value = parseInt($(this).val()) || 1;
if(value <= 0)
{
value = 1;
}
2019-09-23 09:31:30 +00:00
var spec_count = $('.specifications-table th.table-title').length || 1;
2019-09-23 09:30:05 +00:00
if(value > spec_count)
{
value = spec_count;
}
$(this).val(value);
});
// 自动添加图片规格input禁止冒泡
$('.specifications-line-images-auto-add input').on('click', function()
{
return false;
});
2019-09-22 14:19:24 +00:00
// 规格批量操作-开启
var $spec_modal = $('#spec-modal-all-operation');
2019-09-23 14:39:36 +00:00
$('.specifications-table thead th i.am-icon-edit').on('click', function()
2019-09-22 14:19:24 +00:00
{
$spec_modal.modal({
width: 200,
2019-09-23 14:39:36 +00:00
height: 100,
closeViaDimmer: false
2019-09-22 14:19:24 +00:00
});
$spec_modal.attr('data-index', $(this).parent().index());
$spec_modal.find('.am-input-group input').val('');
});
// 规格批量操作-确认
$spec_modal.find('.am-input-group button').on('click', function()
{
var index = $spec_modal.attr('data-index') || 0;
var value = $spec_modal.find('.am-input-group input').val() || '';
$('.specifications-table tbody tr').each(function(k, v)
{
$(this).find('td').eq(index).find('input').val(value);
});
$spec_modal.modal('close');
});
2018-12-28 10:58:37 +00:00
// 手机详情添加
$(document).on('click', '.content-app-items-add-sub', function()
{
var $content_tag = $('.content-app-items');
var i = (($(this).attr('index') || null) == null) ? parseInt($content_tag.find('li').length) : parseInt($(this).attr('index'));
var index = parseInt(Math.random()*1000001)+i;
var images_name = $content_tag.data('images-name');
var content_name = $content_tag.data('content-name');
var images_text = $content_tag.data('images-text');
var content_text = $content_tag.data('content-text');
var delete_text = $content_tag.data('delete-text');
var drag_sort_text = $content_tag.data('drag-sort-text');
var html = '<li><div>';
// 左侧
html += '<div class="content-app-left">';
html += '<label class="block">图片</label>';
html += '<ul class="plug-file-upload-view goods-content-app-images-view-'+index+'" data-form-name="'+images_name+'_'+index+'" data-max-number="1" data-dialog-type="images">';
html += '</ul>';
html += '<div class="plug-file-upload-submit" data-view-tag="ul.goods-content-app-images-view-'+index+'">+上传图片</div>';
html += '</div>';
// 右侧
html += '<div class="am-form-group content-app-right fr">';
html += '<label>文本内容</label>';
html += '<textarea rows="3" name="'+content_name+'_'+index+'" class="am-radius" placeholder="'+content_text+'" data-validation-message=""></textarea>';
html += '</div>';
html += '</div>';
// 操作按钮
html += '<i class="c-p fs-12 cr-red content-app-items-rem-sub">删除</i>';
html += ' <i class="c-m fs-12 drag-sort-submit">拖拽排序</i>';
html += '</li>';
$content_tag.append(html);
$content_tag.attr('index', index);
$(this).attr('index', i+1);
});
// 手机详情删除
$(document).on('click', '.content-app-items-rem-sub', function()
{
$(this).parent().remove();
});
// 拖拽
$('ul.goods-photo-view').dragsort({ dragSelector: 'img', placeHolderTemplate: '<li class="drag-sort-dotted"></li>'});
$('ul.content-app-items').dragsort({ dragSelector: 'i.drag-sort-submit', placeHolderTemplate: '<li class="drag-sort-dotted"></li>'});
2019-07-21 15:51:47 +00:00
// 规格扩展数据编辑
var $extends_popup = $('#specifications-extends-popup');
$(document).on('click', '.specifications-table .line-extend-btn', function()
{
$extends_popup.attr('data-line-extend', $(this).parents('tr').attr('data-line-tag'));
$extends_popup.find('input,select,textarea').val('');
var json = $(this).prev().val() || null;
if(json != null)
{
FormDataFill(JSON.parse(json), '#specifications-extends-popup');
}
$extends_popup.modal();
});
2019-09-11 13:06:04 +00:00
// 快捷操作
// 规格列添加
$('.quick-spec-title-add').on('click', function()
{
var spec_max = $('#goods-nav-operations').data('spec-add-max-number') || 3;
if($('.spec-quick table tbody tr').length >= spec_max)
{
Prompt('最多添加'+spec_max+'列规格');
return false;
}
2019-09-23 05:56:03 +00:00
var index = parseInt(Math.random()*1000001);
2019-09-12 10:31:25 +00:00
var html = '<tr>';
html += '<td class="am-text-middle">';
2019-09-23 05:56:03 +00:00
html += '<i class="am-close am-close-spin quick-title-remove">×</i>';
html += '<input type="text" name="spec_base_title_'+index+'" placeholder="规格名" />';
2019-09-12 10:31:25 +00:00
html += '</td>';
html += '<td class="spec-quick-td-value am-cf">';
html += '<div class="am-fl am-margin-xs value-item am-text-left">';
2019-09-23 05:56:03 +00:00
html += '<span class="business-operations-submit quick-spec-value-add" data-index="'+index+'">+添加规格值</span>';
2019-09-12 10:31:25 +00:00
html += '</div>';
html += '</td>';
html += '</tr>';
$('.spec-quick table tbody').append(html);
$('.spec-quick .goods-specifications').show();
});
// 添加规格值
$(document).on('click', '.spec-quick table .quick-spec-value-add', function()
{
2019-09-23 05:56:03 +00:00
var index = $(this).data('index');
2019-09-12 10:31:25 +00:00
var html = '<div class="am-fl am-margin-xs value-item">';
2019-09-23 05:56:03 +00:00
html += '<input type="text" class="am-fl" name="spec_base_value_'+index+'[]" placeholder="规格值" />';
html += '<i class="am-close am-close-spin quick-value-remove">×</i>';
2019-09-12 10:31:25 +00:00
html += '</div>';
$(this).parent().before(html);
});
// 规格名称移除
$(document).on('click', '.spec-quick table .quick-title-remove', function()
{
$(this).parents('tr').remove();
if($('.spec-quick table tbody tr').length <= 0)
{
$('.spec-quick .goods-specifications').hide();
}
});
// 规格值移除
$(document).on('click', '.spec-quick table .value-item .quick-value-remove', function()
{
$(this).parent().remove();
2019-09-11 13:06:04 +00:00
});
// 生成规格
$('.quick-spec-created').on('click', function()
{
2019-09-20 11:02:08 +00:00
var spec = [];
$('.spec-quick table tbody tr').each(function(k, v)
{
spec[k] = {
"title": $(this).find('td.am-text-middle input').val(),
"value": []
}
$(this).find('td.spec-quick-td-value .value-item').each(function(ks,vs)
{
var value = $(this).find('input').val() || null;
if(value != null)
{
spec[k]['value'][ks] = $(this).find('input').val();
}
});
});
// 是否存在规格
if(spec.length <= 0)
{
Prompt('快捷操作规格为空');
2019-09-22 02:07:33 +00:00
return false;
2019-09-20 11:02:08 +00:00
}
2019-09-23 09:30:05 +00:00
// 操作确认
AMUI.dialog.confirm({
title: '温馨提示',
content: '生成规格将清空现有规格数据、是否继续?',
onConfirm: function(options)
2019-09-22 02:07:33 +00:00
{
2019-09-23 09:30:05 +00:00
// 移除所有规格列
$('.specifications-table .title-nav-remove').trigger('click');
// 添加规格列
for(var i in spec)
{
var index = parseInt(Math.random()*1000001);
// title
html = '<th class="table-title table-title-'+index+'">';
html += '<i class="am-close am-close-spin title-nav-remove" data-index="'+index+'">&times;</i>';
html += '<input type="text" name="specifications_name_'+index+'" value="'+spec[i]['title']+'" placeholder="规格名" class="am-radius" data-validation-message="请填写规格名" required />';
html += '</th>';
$('.title-start').before(html);
// value
html = '<td class="table-value table-value-'+index+'">';
html += '<input type="text" name="specifications_value_'+index+'[]" value="'+(spec[i]['value'][0] || "")+'" placeholder="规格值" class="am-radius" data-validation-message="请填写规格值" required />';
html += '</td>';
$('.value-start').before(html);
}
2019-09-20 11:02:08 +00:00
2019-09-23 09:30:05 +00:00
// 自动生成规格
var data = SpecCartesian(spec);
for(var i=1; i<data.length; i++)
{
// 添加规格值
var html = $('.specifications-table').find('tbody tr:last').prop('outerHTML');
if(html.indexOf('<!--operation-->') >= 0)
{
html = html.replace(/<!--operation-->/ig, '<span class="fs-12 cr-blue c-p m-r-5 line-copy">复制</span> <span class="fs-12 cr-red c-p line-remove">移除</span>');
}
$('.specifications-table').append(html);
$('.specifications-table').find('tbody tr:last').attr('class', 'line-'+index+' line-not-first');
$('.specifications-table').find('tbody tr:last').attr('data-line-tag', '.line-'+index);
// 规格值
var temp_spec = data[i].split(',');
for(var k in temp_spec)
{
// 规格值赋值
$('.specifications-table').find('tbody tr:last').find('td:eq('+k+') input').val(temp_spec[k]);
}
}
},
onCancel: function(){}
});
2019-09-11 13:06:04 +00:00
});
2018-12-28 10:58:37 +00:00
});