2023-11-22 11:17:56 +08:00

538 lines
22 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
use app\models\Store;
/**
* @author Any
* @description KISS
* @date 2021年6月30日
* @version 1.0.0
*
* _____LOG_____
*
*/
$this->title = '设备列表';
$this->params['breadcrumbs'][] = $this->title;
?>
<style type="text/css">
.layui-table-cell {
height: auto;
}
</style>
<div class="layui-fluid">
<div class="layui-card">
<div class="layui-card-header">
<?= $this->title ?>
</div>
<div class="layui-card-header layuiadmin-card-header-auto">
<div class="layui-form-item">
<div class="layui-inline">
<!--<a class=" layui-btn" href="<?= \Yii::$app->urlManager->createUrl(["store/feedback/edit"]) ?>">添加反馈</a>-->
</div>
<div class="layui-inline layui-float-right layui-form">
<!-- <div class="layui-inline layui-form-item">-->
<!-- <div class="layui-input-inline">-->
<!-- <select class="layui-select" name="status">-->
<!-- <option value="" -->
<? //=$status === null ? 'selected' : ''?><!--全部状态</option>
<!-- --><?php //foreach ($status_labels as $key => $val):?>
<!-- <option value="--><? //=$key?><!--" -->
<? //=$status == $key && $status != null ? 'selected' : ''?><!--><? //=$val?><!--</option>-->
<!-- --><?php //endforeach;?>
<!-- </select>-->
<!-- </div>-->
<!-- </div>-->
<div class="layui-inline layui-form-item">
<label class="layui-form-label">关键词</label>
<div class="layui-input-block">
<input type="text" name="keywords" placeholder="搜索设备名称,设备编号" autocomplete="off"
class="layui-input"
value="<?= \Yii::$app->request->get("keywords") ?>">
</div>
</div>
<div class="layui-inline">
<button class="layui-btn layuiadmin-btn-useradmin" lay-submit lay-filter="dtable-search">
<i class="layui-icon layui-icon-search layuiadmin-button-btn"></i>
</button>
</div>
</div>
</div>
</div>
<div class="layui-card-body">
<table id="dtable" lay-filter="dtable"></table>
</div>
</div>
</div>
<!--工具栏模板-->
<script type="text/html" id="toolBarTpl">
<div class="layui-btn-container">
<!-- <button class="layui-btn layui-btn-sm layui-btn-normal" lay-event="batch_status_yes">批量营业</button>-->
<!-- <button class="layui-btn layui-btn-sm layui-btn-danger" lay-event="batch_status_no">批量停业</button>-->
<!-- <button class="layui-btn layui-btn-sm layui-btn-danger" lay-event="batch_delete">批量删除</button> -->
<button class="layui-btn layui-btn-sm" lay-event="batch_qrcode">打包二维码</button>
</div>
</script>
<!--行操作列模板-->
<script type="text/html" id="rowBarTpl">
<button class="layui-btn layui-btn-xs layui-btn-normal" lay-event="qrcode">查看二维码</button>
<button class="layui-btn layui-btn-xs layui-btn-normal" lay-event="wechatqrcode">查看公众号二维码</button>
<button class="layui-btn layui-btn-xs layui-btn-normal" lay-event="edit">编辑</button>
{{# if(d.initial_path){ }}
<a href="{{d.initial_path}}"
download="{{d.initial_name}}.{{d.initial_path_ext}}">
<button class="layui-btn layui-btn-xs layui-btn-normal" lay-event="">下载初始模型</button>
</a>
{{# } }}
{{# if(d.final_path){ }}
<a href="{{d.final_path}}"
download="{{d.final_name}}.{{d.final_path_ext}}">
<button class="layui-btn layui-btn-xs layui-btn-danger" lay-event="">下载最终模型</button>
</a>
{{# } }}
{{# if(d.pdf_path){ }}
<a href="{{d.pdf_path}}"
download="{{d.pdf_name}}.{{d.pdf_path_ext}}">
<button class="layui-btn layui-btn-xs layui-btn-danger" lay-event="">下载PDF报告</button>
</a>
{{# } }}
<!-- <button class="layui-btn layui-btn-xs" lay-event="edit">编辑</button>-->
<!-- <button class="layui-btn layui-btn-xs layui-btn-danger" lay-event="delete">删除</button>-->
</script>
<script type="text/html" id="statusTpl">
{{# if(d.status == '0'){ }}
<span class="layui-badge layui-bg-blue">正常</span>
{{# } else{ }}
<span class="layui-badge layui-bg-red">停用</span>
{{# } }}
</script>
<script>
<?php $this->beginBlock('js_script_wrap') ?>
layui.config({
base: '/statics/layuiadmin/' //静态资源所在路径
}).extend({
index: 'lib/index' //主入口模块
}).use(['index', 'user', 'table', 'form'], function () {
var $ = layui.$
, form = layui.form
, table = layui.table
, admin = layui.admin;
form.render();
//search
form.on('submit(dtable-search)', function (obj) {
var field = obj.field;
reload_table_data(field);
});
//重新加载表格数据
function reload_table_data(conf) {
table.reload('dtable', {
url: '<?=\Yii::$app->urlManager->createUrl(['store/report/index'])?>'
, page: true
, where: conf
});
};
//执行渲染
table.render({
//指定原始表格元素选择器推荐id选择器
elem: '#dtable'
//容器高度
//,height: 315
//容器宽度
//,width: 720
//设置表头
, cols: [[
{checkbox: true}
, {field: 'id', title: 'ID', width: 80}
, {field: 'name', title: '设备名称', width: 150}
, {field: 'dev_number', title: '设备编号', width: 180}
, {field: 'store_name', title: '门店名称'}
// , {field: 'model_number', title: '模型编号'}
// , {field: 'initial_name', title: '初始模型'}
// , {field: 'final_name', title: '最终模型'}
// , {field: 'pdf_name', title: 'PDF报告'}
, {field: 'status', title: '状态', templet: '#statusTpl', width: 80}
, {field: 'created_at_cn', title: '创建时间', width: 150}
, {title: '操作', fixed: 'right', toolbar: '#rowBarTpl', width: 280}
]
]
, url: '<?=\Yii::$app->urlManager->createUrl(['store/dev/index'])?>'
, page: true
//指向自定义工具栏模板选择器
, toolbar: '#toolBarTpl'
//头部工具栏右侧的图标按钮
, defaultToolbar: []
, limit: 20
, limits: [10, 20, 30, 40, 50, 60, 70, 80, 90, 100]
, title: '<?=$this->title?>'
, data: []
, done: function (res, curr, count) {
setTimeout(function () {
$(".layui-table-main tr").each(function (index, val) {
$(".layui-table-fixed").each(function () {
$($(this).find(".layui-table-body tbody tr")[index]).height($(val).height());
});
});
$(".layui-table-header tr").each(function (index, val) {
$(".layui-table-fixed").each(function () {
$($(this).find(".layui-table-header thead tr")[index]).height($(val).height());
});
});
}, 500);
}
});
//监听工具条
table.on('tool(dtable)', function (obj) {
var row_data = obj.data;
var lay_event = obj.event;
var id = row_data.id;
var confirm_url = null;
var confirm_tip = null;
var ids = [];
ids.push(id);
if (lay_event == "delete") {
confirm_url = "<?=\Yii::$app->urlManager->createUrl(['store/store/delete'])?>";
confirm_tip = "确定删除此门店吗";
}
if (lay_event == "status_yes") {
confirm_url = "<?=\Yii::$app->urlManager->createUrl(['store/store/status-yes'])?>";
confirm_tip = "确定此门店变更为营业吗?";
}
if (lay_event == "status_no") {
confirm_url = "<?=\Yii::$app->urlManager->createUrl(['store/store/status-no'])?>";
confirm_tip = "确定此门店变更为停业吗?";
}
//if (lay_event == "find_qrcode") {
// confirm_url = "<?//=\Yii::$app->urlManager->createUrl(['store/report/edit'])?>//";
// confirm_tip = "确定上传报告吗?";
//}
if (lay_event == 'edit') {
confirm_url = "<?=\Yii::$app->urlManager->createUrl(['store/dev/edit'])?>" + "?id=" + id;
location.href = confirm_url;
return;
}
if (lay_event == "qrcode") {
confirm_url = "<?=\Yii::$app->urlManager->createUrl(['store/dev/qrcode'])?>";
confirm_tip = "确定查看此设备二维码吗?";
layer.closeAll()
layer.load(2);
return $.ajax(confirm_url, {
type: "POST",
dataType: "json",
data: {
ids: ids,
_csrf: _csrf
},
success: function (res) {
layer.closeAll('loading');
if (res.code == 0) {
var imgHtml = "<img src='" + res.data + "' width='500px' height='500px'/>";
//弹出层
layer.open({
type: 1,
shade: 0,
offset: 'auto',
area: 'auth',
shadeClose: true,
scrollbar: false,
title: "图片预览", //不显示标题
content: imgHtml, //捕获的元素注意最好该指定的元素要存放在body最外层否则可能被其它的相对元素所影响
});
} else {
layer.msg(res.msg, {
offset: '15px'
, icon: 2
, time: 1000
}, function () {
});
}
},
error: function (xhr, type, err) {
layer.closeAll('loading');
layer.msg(xhr.responseText, {
offset: '15px'
, icon: 2
, time: 1000
}, function () {
});
}
})
}
if (lay_event == "wechatqrcode") {
confirm_url = "<?=\Yii::$app->urlManager->createUrl(['store/dev/qr-wechatcode'])?>";
confirm_tip = "确定查看此设备二维码吗?";
layer.closeAll()
layer.load(2);
return $.ajax(confirm_url, {
type: "POST",
dataType: "json",
data: {
ids: ids,
_csrf: _csrf
},
success: function (res) {
layer.closeAll('loading');
if (res.code == 0) {
var imgHtml = "<img src='" + res.data + "' width='500px' height='500px'/>";
//弹出层
layer.open({
type: 1,
shade: 0,
offset: 'auto',
area: 'auth',
shadeClose: true,
scrollbar: false,
title: "图片预览", //不显示标题
content: imgHtml, //捕获的元素注意最好该指定的元素要存放在body最外层否则可能被其它的相对元素所影响
});
} else {
layer.msg(res.msg, {
offset: '15px'
, icon: 2
, time: 1000
}, function () {
});
}
},
error: function (xhr, type, err) {
layer.closeAll('loading');
layer.msg(xhr.responseText, {
offset: '15px'
, icon: 2
, time: 1000
}, function () {
});
}
})
}
if (confirm_url != null) {
layer.confirm(confirm_tip, {
btn: ['确定', '取消']
}, function (index) {
layer.close(index)
$.ajax(confirm_url, {
type: "POST",
dataType: "json",
data: {
ids: ids,
_csrf: _csrf
},
success: function (res) {
if (res.code == 0) {
if (lay_event == 'find_qrcode') {
var imgHtml = "<img src='" + res.data + "' width='500px' height='500px'/>";
//弹出层
layer.open({
type: 1,
shade: 0,
offset: 'auto',
area: 'auth',
shadeClose: true,
scrollbar: false,
title: "图片预览", //不显示标题
content: imgHtml, //捕获的元素注意最好该指定的元素要存放在body最外层否则可能被其它的相对元素所影响
});
} else {
layer.msg(res.msg, {
offset: '15px'
, icon: 1
, time: 1000
}, function () {
location.reload();
});
}
} else {
layer.msg(res.msg, {
offset: '15px'
, icon: 2
, time: 1000
}, function () {
});
}
},
error: function (xhr, type, err) {
layer.msg(xhr.responseText, {
offset: '15px'
, icon: 2
, time: 1000
}, function () {
});
}
})
}, function () {
});
}
});
//监听工具栏
table.on('toolbar(dtable)', function (obj) {
var lay_event = obj.event;
var check_status = table.checkStatus('dtable');
var ids = [];
$(check_status.data).each(function (index) {
ids.push(check_status.data[index]['id']);
});
if (lay_event == 'batch_qrcode') {
confirm_url = "<?=\Yii::$app->urlManager->createUrl(['store/dev/batch-qrcode'])?>";
location.href = confirm_url;
return;
}
if (ids.length == 0) {
return layer.msg("请选择需要操作项");
}
var confirm_url = null;
var confirm_tip = null;
if (lay_event == 'batch_delete') {
confirm_url = "<?=\Yii::$app->urlManager->createUrl(['store/store/delete'])?>";
confirm_tip = "确定将选中门店删除吗";
}
if (lay_event == 'batch_status_yes') {
confirm_url = "<?=\Yii::$app->urlManager->createUrl(['store/store/status-yes'])?>";
confirm_tip = "确定将选中门店变更为营业吗";
}
if (lay_event == 'batch_status_no') {
confirm_url = "<?=\Yii::$app->urlManager->createUrl(['store/store/status-no'])?>";
confirm_tip = "确定将选中门店变更为停业吗";
}
if (confirm_url != null) {
layer.confirm(confirm_tip, {
btn: ['确定', '取消']
}, function () {
$.ajax(confirm_url, {
type: "POST",
dataType: "json",
data: {
ids: ids,
_csrf: _csrf
},
success: function (res) {
if (res.code == 0) {
layer.msg(res.msg, {
offset: '15px'
, icon: 1
, time: 1000
}, function () {
location.reload();
});
} else {
layer.msg(res.msg, {
offset: '15px'
, icon: 2
, time: 1000
}, function () {
});
}
},
error: function (xhr, type, err) {
layer.msg(xhr.responseText, {
offset: '15px'
, icon: 2
, time: 1000
}, function () {
});
}
})
}, function () {
});
}
});
form.on('select(province)', function (res) {
app.province_id = res.value;
$(app.province).each(function (i) {
if (app.province[i].id == app.province_id) {
app.city = app.province_id != 0 ? app.province[i].list : [];
//app.city_id = app.province_id != 0 ? app.province[i].list[0]['id'] : 0;
app.area = app.province_id != 0 ? app.city[0].list : [];
//app.area_id = app.province_id != 0 ? app.city[0].list[0]['id'] : 0;
app.province_id = app.province_id == 0 ? '' : app.province_id;
app.$forceUpdate();
setTimeout(function () {
form.render('select');
}, 500);
return true;
}
});
});
form.on('select(city)', function (res) {
app.city_id = res.value;
$(app.city).each(function (i) {
if (app.city[i].id == app.city_id) {
app.area = app.city[i].list;
//app.area_id = app.city[i].list[0]['id'];
app.$forceUpdate();
setTimeout(function () {
form.render('select');
}, 500);
return true;
}
});
});
form.on('select(area)', function (res) {
app.area_id = res.value;
setTimeout(function () {
form.render('select');
}, 500);
});
});
function previewImg(obj) {
var img = new Image();
img.src = obj.src;
var imgw = img.width;
var imgh = img.height;
var img_th = imgh / imgw * 500;
var imgHtml = "<img src='" + obj.src + "' width='500px' height='" + img_th + "px'/>";
//弹出层
layer.open({
type: 1,
shade: 0.8,
offset: 'auto',
area: [500 + 'px', (img_th + 50) + 'px'],
shadeClose: true,
scrollbar: false,
title: "图片预览", //不显示标题
content: imgHtml, //捕获的元素注意最好该指定的元素要存放在body最外层否则可能被其它的相对元素所影响
cancel: function () {
//layer.msg('捕获就是从页面已经存在的元素上包裹layer的结构', { time: 5000, icon: 6 });
}
});
}
<?php $this->endBlock(); ?>
</script>
<?php $this->registerJs($this->blocks['js_script_wrap'], \yii\web\View::POS_END); ?>