Index.cshtml 11.9 KB
@using HHECS.DAQWebClient.Model
@using HHECS.DAQWebClient.ViewModel
@model CommunicationQueryModel
@{
    ViewData["Title"] = "通讯配置";
    var communicationTypes = Enum.GetValues(typeof(CommunicationTypeConst)).Cast<CommunicationTypeConst>().Select(x => new SelectListItem { Value = ((int)x).ToString(), Text = x.ToString() }).ToList();
    var isAdmin = User.IsInRole(nameof(RoleType.Admin));
}

<div class="layui-card">
    <div class="layui-card-body">
        <form class="layui-form layui-form-pane" id="form-val-filter" lay-filter="form-val-filter">
            <div class="layui-inline">
                <label class="layui-form-label">设备编号</label>
                <div class="layui-input-inline">
                    <input type="text" asp-for="Code" placeholder="" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">设备名称</label>
                <div class="layui-input-inline">
                    <input type="text" asp-for="Name" placeholder="" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">类型</label>
                <div class="layui-input-inline">
                    <select asp-for="CommunicationType" asp-items="communicationTypes">
                        <option value="" selected>全部</option>
                    </select>
                </div>
            </div>
        </form>
    </div>
</div>
<div class="layui-panel">
    <table class="layui-hide" id="tableDemo" lay-filter="tableDemo"></table>
</div>

<div id="ID-layer-addOrEdit" style="display: none; padding: 15px;">
    <partial name="AddOrEdit" model="communicationTypes" />
</div>

<script type="text/html" id="toolbarDemo">
    <div class="layui-btn-container">
        <button class="layui-btn layui-btn-sm" lay-event="search">
            <i class="layui-icon layui-icon-search"></i>
            查询
        </button>
        <button class="layui-btn layui-btn-sm layui-btn-primary" lay-event="refresh">
            <i class="layui-icon layui-icon-refresh"></i>
            重置
        </button>
        <button class="layui-btn layui-btn-sm layui-btn-normal @(isAdmin?"":"layui-hide")" lay-event="add">
            <i class="layui-icon layui-icon-add-1"></i>
            新增
        </button>
        <button class="layui-btn layui-btn-sm layui-btn-danger @(isAdmin?"":"layui-hide")" lay-event="batchDelete">
            <i class="layui-icon layui-icon-delete"></i>
            批量删除
        </button>
    </div>
</script>
<script type="text/html" id="toolDisable">
    <input type="checkbox" name="disable" value="{{= d.id }}" lay-filter="disable-switch-filter" lay-skin="switch" {{= d.disable == false ? "checked" : "" }} title="启用|禁用">
</script>
<partial name="_DateTimeFormatPartial" />
<script type="text/html" id="toolDemo">
    <div class="layui-clear-space">
        <a class="layui-btn layui-btn-xs layui-btn-warm" lay-event="edit"><i class="layui-icon layui-icon-edit"></i>编辑</a>
        <a class="layui-btn layui-btn-xs layui-btn-danger" lay-event="delete"><i class="layui-icon layui-icon-delete"></i>删除</a>
    </div>
</script>

<script type="text/html" id="communicationTypeTemp">
    @foreach (var item in Enum.GetValues<CommunicationTypeConst>())
    {
        <span>
            {{#  if(d.communicationType == @((int)item)){  }}
            @item.ToString()
            {{#  } }}
        </span>
    }
</script>

@section Scripts{
    <script type="text/javascript" asp-append-version="true">
        layui.use(['table', 'form'], function () {
            var table = layui.table;
            var form = layui.form;
            var $ = layui.$;

            // 创建渲染实例
            table.render({
                elem: '#tableDemo',
                url: 'Load', // 此处为静态模拟数据,实际使用时需换成真实接口
                toolbar: '#toolbarDemo',
                defaultToolbar: ['filter', 'exports', 'print'],
                height: 'full-200', // 最大高度减去其他容器已占有的高度差
                cellMinWidth: 80,
                page: true,
                cols: [[
                    { type: 'checkbox', fixed: 'left' },
                    { field: 'id', fixed: 'left', title: 'ID', hide: true },
                    { field: 'code', fixed: 'left', width: 150, title: '设备编号' },
                    { field: 'name', width: 150, title: '设备名称' },
                    { field: 'communicationType', width: 150, title: '类型', templet: '#communicationTypeTemp' },
                    { field: 'ipAddress', width: 150, title: 'IP地址' },
                    { field: 'port', width: 30, title: '端口' },
                    { field: 'disable', width: 90, title: '状态', templet: '#toolDisable' },
                    { field: 'remark', minWidth: 240, title: '备注' },
                    { field: 'createdBy', title: '创建人', hide: true },
                    { field: 'created', width: 160, title: '创建时间', templet: '#toolCreated' },
                    { field: 'updatedBy', title: '更新人', hide: true },
                    { field: 'updated', width: 160, title: '更新时间', templet: '#toolUpdated' },
                    { fixed: 'right', title: '操作', width: 140,@(isAdmin?"": "hide:true,") templet: '#toolDemo' }
                ]],
                error: function (res, msg) {
                    console.log(res, msg)
                }
            });

            // 工具栏事件
            table.on('toolbar(tableDemo)', function (obj) {
                var id = obj.config.id;
                var checkStatus = table.checkStatus(id);
                var othis = lay(this);
                switch (obj.event) {
                    case 'search':
                        search();
                        break;
                    case 'refresh':
                        refresh();
                        break;
                    case 'add':
                        add();
                        break;
                    case 'batchDelete':
                        batchDelete(checkStatus.data);
                        break;
                };
            });

            // 触发单元格工具事件
            table.on('tool(tableDemo)', function (obj) {
                let data = obj.data; // 获得当前行数据
                if (obj.event === 'edit') {
                    edit(data);
                } else if (obj.event === 'delete') {
                    batchDelete([data]);
                }
            })

            // checkbox 事件
            form.on('switch(disable-switch-filter)', function (obj) {
                let id = this.value;
                let elem = obj.elem;
                let disable = elem.checked == false;
                let data = {
                    id: id,
                    disable: disable
                }
                $.post('UpdateStatus', data).done(function (result) {
                    if (result.code == 0) {
                        table.reloadData('tableDemo');
                        layer.msg(result.msg, { icon: 1 })
                    } else {
                        $(elem).prop('checked', !elem.checked)
                        layer.msg(result.msg, { icon: 2 })
                    }
                }).fail(function (xhr, status, error) {
                    $(elem).prop('checked', !elem.checked)
                    layer.msg(`操作失败,状态码${xhr.status},${error}`, { icon: 2 });
                })
            });

            function search() {
                let data = form.val('form-val-filter');
                table.reloadData('tableDemo', {
                    where: data,
                    scrollPos: true,
                });
            }

            function refresh() {
                $("#form-val-filter")[0].reset();
                table.reloadData('tableDemo', {
                    where: {},
                });
            }

            function add() {
                layer.open({
                    title: '新增',
                    type: 1,
                    area: ['600px', 'auto'],
                    content: $('#ID-layer-addOrEdit'),
                    btn: ['保存', '取消'],
                    yes: function (index, layero, that) {
                        var isValid = form.validate('#form-addOrEdit-filter')
                        if (!isValid) {
                            return false;
                        }
                        let data = form.val('form-addOrEdit-filter');
                        data.disable = data.disable === 'on' ? false : true;
                        $.post('Add', data).done(function (result) {
                            if (result.code === 0) {
                                table.reloadData('tableDemo');
                                layer.msg(result.msg, { icon: 1 });
                                layer.close(index);
                            } else {
                                layer.msg(result.msg, { icon: 2 });
                            }
                        }).fail(function (xhr, status, error) {
                            layer.msg(`操作失败,状态码${xhr.status},${error}`, { icon: 2 });
                        });
                        return false;
                    },
                    end: function () {
                        //关闭后的回调
                        $("#form-addOrEdit-filter")[0].reset();
                    }
                });
            }

            function edit(data) {
                form.val('form-addOrEdit-filter', data);
                $('#switchDisable')[0].checked = data.disable == false;
                layer.open({
                    title: '编辑 - id:' + data.id,
                    type: 1,
                    area: ['600px', 'auto'],
                    content: $('#ID-layer-addOrEdit'),
                    btn: ['保存', '取消'],
                    yes: function (index, layero, that) {
                        var isValid = form.validate('#form-addOrEdit-filter')
                        if (!isValid) {
                            return false;
                        }
                        let data = form.val('form-addOrEdit-filter');
                        data.disable = data.disable === 'on' ? false : true;
                        $.post('Update', data).done(function (result) {
                            if (result.code === 0) {
                                table.reloadData('tableDemo');
                                layer.msg(result.msg, { icon: 1 });
                                layer.close(index); // 关闭弹层
                            } else {
                                layer.msg(result.msg, { icon: 2 });
                            }
                        }).fail(function (xhr, status, error) {
                            layer.msg(`操作失败,状态码${xhr.status},${error}`, { icon: 2 });
                        });
                        return false;
                    },
                    end: function () {
                        //关闭后的回调
                        $("#form-addOrEdit-filter")[0].reset();
                    }
                });
            }

            function batchDelete(data) {
                layer.confirm('确定删除?', { icon: 3 }, function () {
                    let ids = data.map(x => x.id);
                    $.post('Delete', { ids: ids }).done(function (result) {
                        if (result.code === 0) {
                            table.reloadData('tableDemo');
                            layer.msg(result.msg, { icon: 1 });
                        } else {
                            layer.msg(result.msg, { icon: 2 });
                        }
                    }).fail(function (xhr, status, error) {
                        layer.msg(`操作失败,状态码${xhr.status},${error}`, { icon: 2 });
                    });
                });
            }
        });
    </script>
}