You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
521 lines
24 KiB
521 lines
24 KiB
<!DOCTYPE html>
|
|
<!--suppress JSAnnotator -->
|
|
<html lang="zh-CN">
|
|
<head>
|
|
<link rel="stylesheet" href="{__FRAME_PATH}font-awesome/css/font-awesome.min.css">
|
|
<link href="{__PLUG_PATH}layui/css/layui.css" rel="stylesheet">
|
|
<link rel="stylesheet" href="{__ADMIN_PATH}css/images.css?v=100">
|
|
<script src="{__PLUG_PATH}jquery-1.10.2.min.js"></script>
|
|
<script src="{__PLUG_PATH}layui/layui.all.js"></script>
|
|
<script src="{__PLUG_PATH}vue/dist/vue.min.js"></script>
|
|
</head>
|
|
<style>
|
|
|
|
</style>
|
|
<body>
|
|
<div v-cloak id="app" class="layui-fluid">
|
|
<div class="layui-fluid-side">
|
|
<div class="layui-tree" lay-filter="LAY-tree-8">
|
|
<div data-id="2" class="layui-tree-set layui-tree-setHide">
|
|
<div class="layui-tree-entry">
|
|
<div class="layui-tree-main" @click="OpenTree({ child: [], id: 0 })">
|
|
<span style="visibility: hidden;" class="layui-tree-iconClick">
|
|
<i class="layui-tree-iconArrow"></i>
|
|
</span>
|
|
<span :class="{ on: pid == 0 }" class="layui-tree-txt">全部图片</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div v-for="(item, index) in categoryList" :key="item.id" :class="{ 'layui-tree-spread': item.isOpen }" data-id="2" class="layui-tree-set layui-tree-setHide">
|
|
<div class="layui-tree-entry">
|
|
<div class="layui-tree-main" @click="OpenTree(item, index)">
|
|
<span :style="{ visibility: item.child.length ? 'visible' : 'hidden' }" class="layui-tree-iconClick">
|
|
<i class="layui-tree-iconArrow"></i>
|
|
</span>
|
|
<span :class="{ on: pid == item.id }" class="layui-tree-txt">{{ item.name }}</span>
|
|
</div>
|
|
<div class="layui-layer layui-layer-tips">
|
|
<div id="" class="layui-layer-content">
|
|
<div class="layui-btn-group layui-tree-btnGroup">
|
|
<i class="layui-icon layui-icon-add-1" data-type="add" @click.stop="addCategory(item)"></i>
|
|
<i class="layui-icon layui-icon-edit" data-type="update" @click.stop="updateCategory(item)"></i>
|
|
<i v-if="!item.child.length" class="layui-icon layui-icon-delete" data-type="del" @click.stop="delCategory(item)"></i>
|
|
</div>
|
|
<i class="layui-layer-TipsG layui-layer-TipsT"></i>
|
|
</div>
|
|
<span class="layui-layer-setwin"></span>
|
|
</div>
|
|
</div>
|
|
<div :style="{ display: item.isOpen ? 'block' : 'none' }" class="layui-tree-pack layui-tree-lineExtend layui-tree-showLine">
|
|
<div v-for="cell in item.child" :key="cell.id" data-id="2000" class="layui-tree-set">
|
|
<div class="layui-tree-entry">
|
|
<div class="layui-tree-main" @click="OpenTree(cell, index)">
|
|
<span class="layui-tree-iconClick" style="visibility: hidden;">
|
|
<i class="layui-tree-iconArrow" style="display: none;"></i>
|
|
</span>
|
|
<span :class="{ on: pid == cell.id }" class="layui-tree-txt">{{ cell.name }}</span>
|
|
</div>
|
|
<div class="layui-layer layui-layer-tips">
|
|
<div id="" class="layui-layer-content">
|
|
<div class="layui-btn-group layui-tree-btnGroup">
|
|
<i class="layui-icon layui-icon-edit" data-type="update" @click.stop="updateCategory(cell)"></i>
|
|
<i class="layui-icon layui-icon-delete" data-type="del" @click.stop="delCategory(cell)"></i>
|
|
</div>
|
|
<i class="layui-layer-TipsG layui-layer-TipsT"></i>
|
|
</div>
|
|
<span class="layui-layer-setwin"></span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="layui-fluid-main">
|
|
<div class="main-header">
|
|
<div class="layui-btn-group">
|
|
<button :class="{ 'layui-btn-normal': selectedImage.length, 'layui-btn-disabled': !selectedImage.length }" type="button" class="layui-btn layui-btn-sm" @click="useImage">使用选中的图片</button>
|
|
<button type="button" class="layui-btn layui-btn-normal layui-btn-sm" @click="addCategory">添加分类</button>
|
|
<button ref="upload" type="button" class="layui-btn layui-btn-normal layui-btn-sm">上传图片</button>
|
|
<button :class="{ 'layui-btn-normal': selectedImage.length, 'layui-btn-disabled': !selectedImage.length }" type="button" class="layui-btn layui-btn-sm" @click="moveCategory">图片移至</button>
|
|
<button :class="{ 'layui-btn-danger': selectedImage.length, 'layui-btn-disabled': !selectedImage.length }" type="button" class="layui-btn layui-btn-sm" @click="deleteImage">删除图片</button>
|
|
<button type="button" class="layui-btn layui-btn-normal layui-btn-sm" @click="searchImage"><i class="layui-icon layui-icon-search"></i></button>
|
|
</div>
|
|
</div>
|
|
<div class="main-content">
|
|
<div v-for="item in imageList" :key="item.att_id" class="image-item">
|
|
<div :class="{ on: item.selected }" class="image-wrap" @click="selectImage(item)">
|
|
<img :src="item.att_dir">
|
|
<span v-show="item.number" class="layui-badge layui-bg-cyan">{{ item.number }}</span>
|
|
<div class="layui-btn-group">
|
|
<button type="button" class="layui-btn layui-btn-primary layui-btn-xs" @click.stop="lookImage(item.att_dir)">
|
|
<i class="fa fa-eye"></i>
|
|
</button>
|
|
<button type="button" class="layui-btn layui-btn-primary layui-btn-xs" @click.stop="handleEdit(item)">
|
|
<i class="fa fa-edit"></i>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
<input :ref="item.att_id" v-model.trim="item.title" type="text" :disabled="item.disabled" @blur="handleBlur(item)">
|
|
</div>
|
|
<img v-if="!imageList.length && !loading" class="empty" src="{__ADMIN_PATH}images/empty.jpg">
|
|
</div>
|
|
<div ref="main-footer" class="main-footer"></div>
|
|
</div>
|
|
</div>
|
|
</body>
|
|
</html>
|
|
<script src="{__ADMIN_PATH}js/layuiList.js"></script>
|
|
<script>
|
|
var form = layui.form;
|
|
var pid = {$pid}, small = {$Request.param.small ? : 0} , parentinputname = '{$fodder}', maxLength = {$maxLength};//当前图片分类ID
|
|
|
|
new Vue({
|
|
el: "#app",
|
|
data: {
|
|
categoryList: [],
|
|
searchTitle: '',
|
|
pid: pid,
|
|
imageList: [],
|
|
page: 1,
|
|
limit: 20,
|
|
loading: false,
|
|
small: small,
|
|
selectedImage: [],
|
|
selectedImageIDS: [],
|
|
uploadInst: null,
|
|
searchContent: '',
|
|
files: {}
|
|
},
|
|
watch: {
|
|
page: function () {
|
|
this.getImageList();
|
|
},
|
|
},
|
|
methods: {
|
|
searchImage: function () {
|
|
var vm = this;
|
|
layer.prompt({
|
|
title: '输入图片名称,并确认',
|
|
formType: 0
|
|
}, function (text, index) {
|
|
if (!text.trim().length) {
|
|
return;
|
|
}
|
|
this.pid = 0;
|
|
this.searchContent = text.trim();
|
|
this.page = 1;
|
|
layer.close(index);
|
|
var load = layer.load(1);
|
|
layList.baseGet(this.U({
|
|
a: 'get_image_list',
|
|
q: {pid: this.pid, page: this.page, limit: this.limit, title: this.searchContent}
|
|
}), function (res) {
|
|
layer.close(load);
|
|
var list = res.data.list;
|
|
list.forEach(function (item) {
|
|
item.disabled = true;
|
|
item.hover = false;
|
|
if (!item.title) {
|
|
item.title = item.name.slice(0, item.name.lastIndexOf('.'));
|
|
}
|
|
});
|
|
this.$set(this, 'imageList', list);
|
|
if (this.page == 1) {
|
|
layList.laypage.render({
|
|
elem: this.$refs['main-footer']
|
|
, count: res.data.count
|
|
, limit: this.limit
|
|
, theme: '#1E9FFF',
|
|
groups: 3,
|
|
jump: function (obj) {
|
|
vm.page = obj.curr;
|
|
}
|
|
});
|
|
}
|
|
}.bind(this), function (res) {
|
|
layer.close(load);
|
|
layList.msg(res.msg);
|
|
});
|
|
}.bind(this));
|
|
},
|
|
handleEdit: function (item) {
|
|
item.disabled = false;
|
|
this.oldTitle = item.title;
|
|
this.$nextTick(function () {
|
|
this.$refs[item.att_id][0].focus();
|
|
});
|
|
},
|
|
handleBlur: function (item) {
|
|
item.disabled = true;
|
|
if (this.oldTitle !== item.title) {
|
|
this.updateTitle(item);
|
|
}
|
|
},
|
|
lookImage: function (image) {
|
|
layui.layer.photos({
|
|
photos: {
|
|
data: [
|
|
{
|
|
src: image
|
|
}
|
|
]
|
|
},
|
|
anim: 5
|
|
});
|
|
},
|
|
// 修改名称
|
|
updateTitle: function (item) {
|
|
layList.basePost(this.U({
|
|
a: 'updateImageTitle'
|
|
}), {
|
|
att_id: item.att_id,
|
|
title: item.title
|
|
}, function (res) {
|
|
layList.msg(res.msg);
|
|
}, function (res) {
|
|
layList.msg(res.msg);
|
|
});
|
|
},
|
|
//删除图片
|
|
deleteImage: function () {
|
|
var that = this;
|
|
if (!this.selectedImage.length) return;
|
|
layList.layer.confirm('是否要删除选中图片?', {
|
|
btn: ['是的我要删除', '我想想吧'] //按钮
|
|
}, function () {
|
|
layList.basePost(that.U({a: 'delete'}), {imageid: that.selectedImageIDS}, function (res) {
|
|
layList.msg(res.msg);
|
|
that.getImageList();
|
|
window.location.reload()
|
|
}, function (res) {
|
|
layList.msg(res.msg);
|
|
})
|
|
})
|
|
},
|
|
//移动图片分类
|
|
moveCategory: function () {
|
|
var that = this;
|
|
window.formSuccessBack = function () {
|
|
that.getImageList();
|
|
that.selectedImage = [];
|
|
that.selectedImageIDS = [];
|
|
};
|
|
this.getOpenWindow('移动图片', this.U({a: 'moveimg'}) + '?imgaes=' + this.selectedImageIDS, {
|
|
end: function () {
|
|
window.formSuccessBack = null;
|
|
}
|
|
});
|
|
},
|
|
//使用选中图片
|
|
useImage: function () {
|
|
if (!this.selectedImage.length) return;
|
|
//判断表单限制图片个数
|
|
if (typeof parent.$f != 'undefined') {
|
|
//已有图片个数
|
|
var nowpics = parent.$f.getValue(parentinputname).length,
|
|
props = parent.$f.model()[parentinputname].props || {},
|
|
maxlength = props.maxLength || 0;
|
|
//已选图片个数
|
|
var selectlength = this.selectedImage.length;
|
|
//还可以选择多少张
|
|
var surplus = maxlength - nowpics;
|
|
if (nowpics + selectlength > maxlength) {
|
|
return layList.msg('最多只能选择 ' + surplus + ' 张');
|
|
}
|
|
}
|
|
//编辑器中
|
|
if (parentinputname.includes('editor')) {
|
|
var list = this.selectedImage.map(function (image) {
|
|
return {
|
|
_src: image,
|
|
src: image
|
|
};
|
|
});
|
|
parent.insertEditor(list, parentinputname);
|
|
var index = parent.layer.getFrameIndex(window.name);
|
|
parent.layer.close(index)
|
|
} else {
|
|
//form表单中
|
|
if (parent.$f) {
|
|
var value = parent.$f.getValue(parentinputname);//父级input 值
|
|
var list = value || [];
|
|
for (var i = 0; i < this.selectedImage.length; i++) {
|
|
if (value.indexOf(this.selectedImage[i]) == -1) list.push(this.selectedImage[i]);
|
|
}
|
|
parent.$f.changeField(parentinputname, list);
|
|
parent.$f.closeModal(parentinputname);
|
|
} else {
|
|
//独立图片选择页面
|
|
if(maxLength > 0 ){
|
|
if(this.selectedImage.length > maxLength){
|
|
return layList.msg('最多能选择' + maxLength + '张');
|
|
}
|
|
parent.changeIMG(parentinputname, this.selectedImage,1);
|
|
}else{
|
|
if(this.selectedImage.length > 1){
|
|
return layList.msg('只能选择一张图片');
|
|
}
|
|
parent.changeIMG(parentinputname, this.selectedImage[0]);
|
|
}
|
|
var index = parent.layer.getFrameIndex(window.name);
|
|
parent.layer.close(index);
|
|
}
|
|
}
|
|
|
|
},
|
|
//图片选中和取消
|
|
selectImage: function (item, index) {
|
|
if (!item.selected) {
|
|
if (maxLength) {
|
|
if (this.selectedImage.length === maxLength) {
|
|
return layList.msg('最多选择' + maxLength + '张图片');
|
|
}
|
|
} else {
|
|
if (parentinputname.indexOf('editor') === -1) {
|
|
if (this.selectedImage.length) {
|
|
return layList.msg('只能选择1张图片');
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
this.$set(item, 'selected', item.selected == undefined ? true : !item.selected);
|
|
var val = small == 1 ? item['satt_dir'] : item['att_dir'];
|
|
if (item.selected === true) {
|
|
this.selectedImage[this.selectedImage.length] = val;
|
|
this.selectedImageIDS[this.selectedImage.length] = item['att_id'];
|
|
item.number = this.selectedImage.length;
|
|
} else {
|
|
this.selectedImage.splice(this.selectedImage.indexOf(val), 1);
|
|
this.selectedImageIDS.splice(this.selectedImage.indexOf(item['att_id']), 1);
|
|
for (var i = 0; i < this.imageList.length; i++) {
|
|
if (this.imageList[i].number > item.number) {
|
|
this.imageList[i].number = (this.imageList[i].number - 1) >= 0 ? this.imageList[i].number - 1 : 0;
|
|
}
|
|
}
|
|
item.number = 0;
|
|
}
|
|
this.$set(this, 'selectedImage', this.selectedImage);
|
|
this.$set(this, 'selectedImageIDS', this.selectedImageIDS);
|
|
},
|
|
//获取图片列表
|
|
getImageList: function () {
|
|
var that = this;
|
|
if (that.loading) return;
|
|
that.loading = true;
|
|
var index = layList.layer.load(1, {shade: [0.1, '#fff']});
|
|
layList.baseGet(this.U({
|
|
a: 'get_image_list',
|
|
q: {pid: this.pid, page: this.page, limit: this.limit, title: that.searchContent }
|
|
}), function (res) {
|
|
that.loading = false;
|
|
|
|
var list = res.data.list;
|
|
for (var i = list.length; i--;) {
|
|
list[i].disabled = true;
|
|
list[i].hover = false;
|
|
if (!list[i].title) {
|
|
list[i].title = list[i].name.slice(0, list[i].name.lastIndexOf('.'));
|
|
}
|
|
}
|
|
that.$set(that, 'imageList', res.data.list);
|
|
layList.layer.close(index);
|
|
if (that.page == 1) {
|
|
layList.laypage.render({
|
|
elem: that.$refs['main-footer']
|
|
, count: res.data.count
|
|
, limit: that.limit
|
|
, theme: '#1E9FFF',
|
|
jump: function (obj) {
|
|
that.page = obj.curr;
|
|
}
|
|
});
|
|
}
|
|
}, function () {
|
|
that.loading = false;
|
|
layList.layer.close(index);
|
|
});
|
|
},
|
|
//查询分类
|
|
search: function () {
|
|
this.getCategoryList();
|
|
},
|
|
//打开和关闭树形
|
|
OpenTree: function (item, index) {
|
|
this.searchContent = '';
|
|
this.pid = item.id;
|
|
if (item.child.length) {
|
|
item.isOpen == undefined ? false : item.isOpen;
|
|
this.$set(this.categoryList[index], 'isOpen', !item.isOpen);
|
|
} else {
|
|
this.page = 1;
|
|
this.$set(this, 'selectedImage', []);
|
|
this.$set(this, 'selectedImageIDS', []);
|
|
this.getImageList();
|
|
}
|
|
this.uploadInst.reload({
|
|
url: this.U({a: 'upload'}) + '?pid=' + this.pid
|
|
});
|
|
},
|
|
//组装URL
|
|
U: function (opt) {
|
|
opt = typeof opt == 'object' ? opt : {};
|
|
return layList.U({m: 'admin', c: "widget.images", a: opt.a || '', q: opt.q || {}, p: opt.q || {}});
|
|
},
|
|
//获取分类
|
|
getCategoryList: function () {
|
|
var that = this;
|
|
layList.baseGet(that.U({a: 'get_image_cate', q: {name: this.searchTitle}}), function (res) {
|
|
that.$set(that, 'categoryList', res.data);
|
|
});
|
|
},
|
|
//鼠标移入显示图标
|
|
changeActive: function (item, indexK, index) {
|
|
if (index)
|
|
this.$set(this.categoryList[indexK]['child'], 'isShow', true);
|
|
else
|
|
this.$set(this.categoryList[indexK], 'isShow', true);
|
|
},
|
|
//鼠标移出隐藏
|
|
removeActive: function (item, indexK, index) {
|
|
if (index)
|
|
this.$set(this.categoryList[indexK]['child'], 'isShow', false);
|
|
else
|
|
this.$set(this.categoryList[indexK], 'isShow', false);
|
|
},
|
|
//添加分类
|
|
addCategory: function (item, pid) {
|
|
item = item == undefined ? {} : item;
|
|
var id = item.id == undefined ? 0 : item.id,
|
|
pid = pid == undefined ? 0 : pid;
|
|
return this.getOpenWindow(item.name ? item.name + '编辑' : '新增分类', this.U({
|
|
a: 'addcate',
|
|
q: {id: pid == 0 ? id : pid}
|
|
}));
|
|
},
|
|
//修改分类
|
|
updateCategory: function (item, pid) {
|
|
item = item == undefined ? {} : item;
|
|
pid = pid == undefined ? 0 : pid;
|
|
return this.getOpenWindow(item.name + '编辑', this.U({a: 'editcate', q: {id: item.id}}));
|
|
},
|
|
//删除分类
|
|
delCategory: function (item, pid) {
|
|
var that = this;
|
|
if (item.child.length) return layList.msg('请先删除子分类再尝试删除此分类!');
|
|
layList.layer.confirm('是否要删除[' + item.name + ']分类?', {
|
|
btn: ['是的我要删除', '我想想吧'] //按钮
|
|
}, function () {
|
|
layList.baseGet(that.U({a: 'deletecate', q: {id: item.id}}), function (res) {
|
|
layList.msg(res.msg, function () {
|
|
that.getCategoryList();
|
|
});
|
|
}, function (err) {
|
|
layList.msg(err.msg);
|
|
});
|
|
});
|
|
},
|
|
//打开一个窗口
|
|
getOpenWindow: function (title, url, opt) {
|
|
opt = opt || {};
|
|
return layList.layer.open({
|
|
type: 2,
|
|
title: title,
|
|
shade: [0],
|
|
area: [opt.w || 340 + "px", opt.h || 265 + 'px'],
|
|
anim: 2,
|
|
content: [url, 'no'],
|
|
end: opt.end || null
|
|
});
|
|
},
|
|
//回调
|
|
SuccessCateg: function () {
|
|
this.getCategoryList();
|
|
},
|
|
renderUpload: function () {
|
|
var vm = this;
|
|
this.uploadInst = layui.upload.render({
|
|
elem: this.$refs.upload,
|
|
url: this.U({ a: 'upload' }),
|
|
acceptMime: 'image/*',
|
|
size: 2097152,
|
|
before: function (obj) {
|
|
layui.layer.load(1);
|
|
vm.files = obj.pushFile();
|
|
var file;
|
|
for (var key in vm.files) {
|
|
if (Object.hasOwnProperty.call(vm.files, key)) {
|
|
file = vm.files[key];
|
|
}
|
|
}
|
|
this.data = {
|
|
pid: vm.pid,
|
|
title: file.name.slice(0, file.name.lastIndexOf('.'))
|
|
};
|
|
},
|
|
done: function (res, index, upload) {
|
|
for (var key in vm.files) {
|
|
if (Object.hasOwnProperty.call(vm.files, key)) {
|
|
delete vm.files[key];
|
|
}
|
|
}
|
|
layui.layer.closeAll('loading');
|
|
layui.layer.msg(res.msg);
|
|
vm.page = 1;
|
|
vm.getImageList();
|
|
},
|
|
error: function (index, upload) {
|
|
layui.layer.closeAll('loading');
|
|
}
|
|
});
|
|
}
|
|
},
|
|
mounted: function () {
|
|
this.getCategoryList();
|
|
this.getImageList();
|
|
window.SuccessCateg = this.SuccessCateg;
|
|
this.renderUpload();
|
|
}
|
|
});
|
|
</script>
|
|
|