gorm wire
This commit is contained in:
@@ -1,285 +0,0 @@
|
||||
{{template "header"}}
|
||||
|
||||
<form class="layui-form" style="padding-bottom: 80px;">
|
||||
{{.CsrfTokenField}}
|
||||
<input type="hidden" id="ID" name="ID" value="{{.Item.ID}}" />
|
||||
|
||||
<div class="layui-tab-content" style="padding-top: 0;">
|
||||
<div class="layui-tab-item layui-show">
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">项目信息</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">选择项目</div>
|
||||
<div class="layui-input-inline" id="ProjectID" style="width: 240px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">项目预算信息</div>
|
||||
<div class="layui-card-body">
|
||||
{{if .Item.ID}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">编号</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.ID}}
|
||||
</div>
|
||||
</div>
|
||||
{{end}}
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">名称</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="Name" name="Name" value="{{.Item.Name}}" lay-verify="required"
|
||||
autocomplete="off" placeholder="请输入名称" class="layui-input" style="width:700px;" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">预算类型</label>
|
||||
<div class="layui-input-inline">
|
||||
<select id="BudgetType" name="BudgetType">
|
||||
{{if eq .Item.BudgetType 1}}
|
||||
<option value="1" selected>支出</option>
|
||||
{{else}}
|
||||
<option value="1">支出</option>
|
||||
{{end}}
|
||||
|
||||
{{if eq .Item.BudgetType 2}}
|
||||
<option value="2" selected>收入</option>
|
||||
{{else}}
|
||||
<option value="2">收入</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">预算类别</label>
|
||||
<div class="layui-input-inline" id="CategoryID" style="width: 240px;"></div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">开始时间</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="StartAt" name="StartAt" value="{{.Item.StartAt}}"
|
||||
lay-verify="required" autocomplete="off" placeholder="请输入名称" class="layui-input" />
|
||||
</div>
|
||||
<label class="layui-form-label">结束时间</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="EndAt" name="EndAt" value="{{.Item.EndAt}}" lay-verify="required"
|
||||
autocomplete="off" placeholder="请输入名称" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">预算金额</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="Amount" name="Amount" value="{{.Item.Amount}}" lay-verify="required"
|
||||
autocomplete="off" placeholder="请输入预算金额" class="layui-input" />
|
||||
</div>
|
||||
<label class="layui-form-label">已支付金额</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="UsedAmount" name="UsedAmount" value="{{.Item.UsedAmount}}"
|
||||
lay-verify="required" autocomplete="off" placeholder="请输入已支付金额" class="layui-input" />
|
||||
</div>
|
||||
<label class="layui-form-label">剩余金额</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="RemainingAmount" name="RemainingAmount"
|
||||
value="{{.Item.RemainingAmount}}" lay-verify="required" autocomplete="off"
|
||||
placeholder="请输入剩余金额" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">备注</label>
|
||||
<div class="layui-input-inline">
|
||||
<textarea id="Remark" name="Remark" class="layui-textarea"
|
||||
style="width: 600px; height: 60px;">{{.Item.Remark}}</textarea>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">其他</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">状态</label>
|
||||
<div class="layui-input-inline">
|
||||
<select id="Status" name="Status">
|
||||
{{range .Statuses}}
|
||||
{{if .Selected}}
|
||||
<option value="{{.Value}}" selected>{{.Name}}</option>
|
||||
{{else}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
{{if .Item.ID}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">创建</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.CreatedName}}
|
||||
({{dateFormat .Item.CreatedAt}})
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">更新</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.UpdatedName}}
|
||||
({{dateFormat .Item.UpdatedAt}})
|
||||
</div>
|
||||
</div>
|
||||
{{end}}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item layui-fixbar btn-fixbar-box">
|
||||
<div class="layui-input-block">
|
||||
{{ submitBtn .AuthorizeMenus "save"}}
|
||||
<button type="button" class="layui-btn layui-btn-primary layui-btn-sm" lay-on="close">
|
||||
<i class="layui-icon layui-icon-close"></i>关闭
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</form>
|
||||
|
||||
{{define "css"}}
|
||||
<style>
|
||||
.layui-body {
|
||||
padding: 15px;
|
||||
left: 0;
|
||||
}
|
||||
|
||||
.loader::after {
|
||||
content: '';
|
||||
}
|
||||
</style>
|
||||
{{end}}
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['jquery', 'form', 'laydate', 'xmSelect', "util"], function () {
|
||||
let $ = layui.jquery;
|
||||
let form = layui.form;
|
||||
let laydate = layui.laydate;
|
||||
let xmSelect = layui.xmSelect;
|
||||
let util = layui.util;
|
||||
|
||||
/**开始时间 */
|
||||
laydate.render({
|
||||
elem: '#StartAt',
|
||||
type: 'date',
|
||||
value: '{{today}}',
|
||||
});
|
||||
|
||||
/**截止时间 */
|
||||
laydate.render({
|
||||
elem: '#EndAt',
|
||||
type: 'date',
|
||||
value: '{{threeMonth}}',
|
||||
});
|
||||
|
||||
laydate.render({
|
||||
elem: '#ApplyAt',
|
||||
type: 'date',
|
||||
value: '{{today}}',
|
||||
});
|
||||
|
||||
// 表单提交
|
||||
form.on('submit(save)', function (data) {
|
||||
$.ajax({
|
||||
url: '/budget/save',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
data: data.field,
|
||||
success: function (result) {
|
||||
if (result.success) {
|
||||
layer.msg(result.msg, { icon: 1, time: 1000 }, function () {
|
||||
parent.layer.close(parent.layer.getFrameIndex(window.name)); // 关闭当前页
|
||||
parent.layui.table.reload("tablelist", {
|
||||
page: { curr: 1 },
|
||||
});
|
||||
});
|
||||
} else {
|
||||
parent.layer.msg(result.msg, { icon: 2 })
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
return false;
|
||||
});
|
||||
|
||||
// 事件绑定
|
||||
util.on("lay-on", {
|
||||
"close": function () {
|
||||
window.parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
}
|
||||
});
|
||||
|
||||
getProject();
|
||||
getCategory();
|
||||
|
||||
function getProject() {
|
||||
$.ajax({
|
||||
url: '/project/data?type=xmselect',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
success: function (res) {
|
||||
xmSelect.render({
|
||||
el: '#ProjectID',
|
||||
// 工具栏
|
||||
radio: true,
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择项目',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'ProjectID',
|
||||
initValue: ['{{.Item.ProjectID}}'],
|
||||
on: function (data) { },
|
||||
});
|
||||
},
|
||||
error: function (err) {
|
||||
// 处理请求错误
|
||||
console.log('请求出错:', err);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function getCategory() {
|
||||
$.ajax({
|
||||
url: '/system/category/data?type=xmselect&letter=budget_category',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
success: function (res) {
|
||||
xmSelect.render({
|
||||
el: '#CategoryID',
|
||||
// 工具栏
|
||||
radio: true,
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择预算类别',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'Category',
|
||||
initValue: ['{{.Item.Category}}'],
|
||||
on: function (data) { },
|
||||
});
|
||||
},
|
||||
error: function (err) {
|
||||
// 处理请求错误
|
||||
console.log('请求出错:', err);
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
@@ -1,276 +0,0 @@
|
||||
{{template "header" .}}
|
||||
|
||||
<!-- 工具栏 -->
|
||||
<script id="toolbar" type="text/html">
|
||||
{{ genBtn .AuthorizeMenus "add"}}
|
||||
<button type="button" lay-event="search" lay-on="search" class="layui-btn layui-btn-primary layui-btn-sm">
|
||||
<i class="layui-icon layui-icon-search"></i>
|
||||
</button>
|
||||
</script>
|
||||
|
||||
<div class="search-layer" id="search-layer" style="display: none;">
|
||||
<div class="layui-form layui-row">
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">开始时间</label>
|
||||
<input type="text" name="timeBegin" id="timeBegin" placeholder="yyyy-MM-dd" readonly
|
||||
value="{{ yearBegin }}" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">结束时间</label>
|
||||
<input type="text" name="timeEnd" id="timeEnd" placeholder="yyyy-MM-dd" readonly value="{{ monthEnd }}"
|
||||
class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">状态</label>
|
||||
<select name="status" id="status">
|
||||
{{range.Statuses}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form layui-row">
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">类别</label>
|
||||
<select id="category" name="category">
|
||||
{{range.Categories}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">来源</label>
|
||||
<select id="source">
|
||||
{{range.Sources}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">名称</label>
|
||||
<input type="text" name="title" id="title" placeholder="请输入名称" autocomplete="off" class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-panel">
|
||||
<table id="tablelist" lay-filter="tablelist"></table>
|
||||
</div>
|
||||
|
||||
<script type="text/html" id="actionBox">
|
||||
{{ genLink .AuthorizeMenus "edit"}}
|
||||
</script>
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['table', 'form', 'jquery', 'laydate', 'util'], function () {
|
||||
let table = layui.table;
|
||||
let form = layui.form;
|
||||
let $ = layui.jquery;
|
||||
let util = layui.util;
|
||||
let laydate = layui.laydate;
|
||||
|
||||
/**开始时间 */
|
||||
laydate.render({
|
||||
elem: '#timeBegin',
|
||||
type: 'datetime',
|
||||
value: '{{ yearBegin }}',
|
||||
ready: function (date) {
|
||||
this.dateTime.hours = 0;
|
||||
this.dateTime.minutes = 0;
|
||||
this.dateTime.seconds = 0;
|
||||
}
|
||||
});
|
||||
|
||||
/**截止时间 */
|
||||
laydate.render({
|
||||
elem: '#timeEnd',
|
||||
type: 'datetime',
|
||||
value: '{{ monthEnd }}',
|
||||
ready: function (date) {
|
||||
this.dateTime.hours = 23;
|
||||
this.dateTime.minutes = 59;
|
||||
this.dateTime.seconds = 59;
|
||||
}
|
||||
});
|
||||
|
||||
// 加载列表
|
||||
table.render({
|
||||
elem: '#tablelist',
|
||||
url: "/budget/list",
|
||||
method: "POST",
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
where: getQueryParams(),
|
||||
// height: 'full-100',
|
||||
height: function () {
|
||||
return $(window).height() - 22;
|
||||
},
|
||||
page: true,
|
||||
limit: 15,
|
||||
limits: [15, 30, 45, 60, 75, 90],
|
||||
cols: [[
|
||||
{ field: 'id', title: '预算编号', align: 'left', fixed: 'left', width: 90 },
|
||||
{ field: 'name', title: '预算名称', align: 'left', fixed: 'left', width: 120 },
|
||||
{ field: 'project_name', title: '关联项目', align: 'left', width: 200 },
|
||||
{ field: 'project_id', title: '项目编号', align: 'left', width: 200 },
|
||||
{
|
||||
field: 'budget_type', title: '预算类型', align: 'center', width: 90, templet: function (row) {
|
||||
switch (row.budget_type) {
|
||||
case 1: return '<span class="table-field-select-01">支出</span>';
|
||||
case 2: return '<span class="table-field-select-04">收入</span>';
|
||||
default: return '其它';
|
||||
}
|
||||
return '';
|
||||
}
|
||||
},
|
||||
{ field: 'category_name', title: '预算类别', align: 'left', width: 100 },
|
||||
// {
|
||||
// field: 'status', title: '状态', align: 'center', width: 90, templet: function (row) {
|
||||
// switch (row.status) {
|
||||
// case 0: return '<span style="color:green;">正常</span>';
|
||||
// case -1: return '<span style="color:red;">删除</span>';
|
||||
// default: return '其它';
|
||||
// }
|
||||
// return '';
|
||||
// }
|
||||
// },
|
||||
{ field: 'start_at', title: '预算开始时间', align: 'left', width: 160, templet: function (d) { return !d.start_at ? '' : util.toDateString(d.start_at) } },
|
||||
{ field: 'end_at', title: '预算结束时间', align: 'left', width: 160, templet: function (d) { return !d.end_at ? '' : util.toDateString(d.end_at) } },
|
||||
{ field: 'amount', title: '预算金额', align: 'left', width: 120 },
|
||||
{ field: 'used_amount', title: '已支付金额', align: 'center', width: 120 },
|
||||
{ field: 'remaining_amount', title: '剩余金额', align: 'center', width: 120 },
|
||||
{ field: 'remark', title: '备注', align: 'left', width: 200 },
|
||||
{ field: 'created_at', title: '创建时间', align: 'center', width: 160, templet: function (d) { return !d.created_at ? '' : util.toDateString(d.created_at) } },
|
||||
{ field: 'created_name', title: '创建人', align: 'center', width: 100 },
|
||||
{ field: 'updated_at', title: '更新时间', align: 'center', width: 160, templet: function (d) { return !d.updated_at ? '' : util.toDateString(d.updated_at) } },
|
||||
{ field: 'updated_name', title: '更新人', align: 'center', width: 100 },
|
||||
{ title: '操作', toolbar: '#actionBox', align: 'center', fixed: 'right', width: 100 },
|
||||
]],
|
||||
skin: 'line',
|
||||
toolbar: '#toolbar',
|
||||
defaultToolbar: [{
|
||||
title: '刷新',
|
||||
layEvent: 'refresh',
|
||||
icon: 'layui-icon-refresh',
|
||||
}, 'filter', 'exports'],
|
||||
request: {
|
||||
pageName: 'page',
|
||||
limitName: 'rows'
|
||||
}
|
||||
});
|
||||
|
||||
// 工具栏
|
||||
table.on('toolbar(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'add': add(); break;
|
||||
case 'search': search(); break;
|
||||
case 'refresh': refresh(); break;
|
||||
}
|
||||
});
|
||||
|
||||
function add(obj) {
|
||||
layer.open({
|
||||
type: 2,
|
||||
// offset: 'r',
|
||||
// anim: 'slideLeft',
|
||||
title: '新增',
|
||||
shade: 0.1,
|
||||
area: ['99%', '98%'],
|
||||
content: "/budget/add"
|
||||
});
|
||||
}
|
||||
|
||||
function search() {
|
||||
layer.open({
|
||||
type: 1,
|
||||
offset: '20px',
|
||||
title: '搜索',
|
||||
content: $('#search-layer'), // 捕获的元素
|
||||
shade: 0.1,
|
||||
shadeClose: false,
|
||||
scrollbar: false,
|
||||
resize: false,
|
||||
move: false,
|
||||
skin: 'search-layer-open',
|
||||
area: ['50%', '350px'],
|
||||
btn: ['搜索', '重置'],
|
||||
btn1: function (index, layero) {
|
||||
search_btn();
|
||||
layer.close(index);
|
||||
},
|
||||
btn2: function (index, layero) {
|
||||
$('#timeBegin').val(formatDate(getCurrentYearStart(), 'YYYY-MM-DD HH:mm:ss'));
|
||||
$('#timeEnd').val(formatDate(getCurrentMonthEnd(), 'YYYY-MM-DD HH:mm:ss'));
|
||||
$('#title').val('');
|
||||
$('#category').val('');
|
||||
$('#source').val('');
|
||||
$('#status').val(9999);
|
||||
form.render('select');
|
||||
return false;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function refresh() {
|
||||
table.reload('tablelist');
|
||||
}
|
||||
|
||||
// 表格项操作按钮
|
||||
table.on('tool(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'edit': edit(obj); break;
|
||||
}
|
||||
});
|
||||
|
||||
function edit(obj) {
|
||||
layer.open({
|
||||
type: 2,
|
||||
// offset: 'r',
|
||||
// anim: 'slideLeft',
|
||||
title: '修改',
|
||||
shade: 0.1,
|
||||
area: ['99%', '98%'],
|
||||
content: "/budget/edit?id=" + obj.data['id']
|
||||
});
|
||||
}
|
||||
|
||||
// 搜索条件
|
||||
function getQueryParams() {
|
||||
return {
|
||||
timeBegin: $('#timeBegin').val(),
|
||||
timeEnd: $('#timeEnd').val(),
|
||||
status: $('#status').val(),
|
||||
category: $('#category').val(),
|
||||
project: $('#project').val(),
|
||||
budgetType: $('#budgetType').val(),
|
||||
title: $('#title').val()
|
||||
};
|
||||
}
|
||||
|
||||
// 搜索
|
||||
function search_btn() {
|
||||
table.reload('tablelist', {
|
||||
where: getQueryParams(),
|
||||
page: {
|
||||
curr: 1
|
||||
}
|
||||
})
|
||||
return false;
|
||||
}
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
186
web/templates/manage/cache/list.tmpl
vendored
186
web/templates/manage/cache/list.tmpl
vendored
@@ -1,186 +0,0 @@
|
||||
{{template "header"}}
|
||||
|
||||
<div class="layui-row layui-col-space15">
|
||||
<div class="layui-collapse">
|
||||
<div class="layui-colla-item">
|
||||
<div class="layui-colla-title">查询</div>
|
||||
<div class="layui-colla-content layui-show">
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-body">
|
||||
<form class="layui-form" action="">
|
||||
{{.CsrfTokenField}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-inline">
|
||||
<input type="text" id="title" placeholder="" class="layui-input">
|
||||
</div>
|
||||
<div class="layui-inline">
|
||||
<button type="button" class="pear-btn pear-btn-md pear-btn-primary" lay-submit
|
||||
lay-filter="user-query">
|
||||
<i class="layui-icon layui-icon-search"></i>
|
||||
查询
|
||||
</button>
|
||||
<button type="reset" class="pear-btn pear-btn-md" lay-submit
|
||||
lay-filter="user-reset">
|
||||
<i class="layui-icon layui-icon-refresh"></i>
|
||||
重置
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- 工具栏 -->
|
||||
<script id="toolbar" type="text/html">
|
||||
</script>
|
||||
|
||||
<div class="layui-card" style="margin-top: 15px;">
|
||||
<div class="layui-card-body">
|
||||
<table id="tablelist" lay-filter="tablelist"></table>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<script type="text/html" id="actionBox">
|
||||
{{ genLink .AuthorizeMenus "refresh"}}
|
||||
</script>
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['table', 'form', 'jquery', 'util'], function () {
|
||||
let table = layui.table;
|
||||
let form = layui.form;
|
||||
let $ = layui.jquery;
|
||||
let util = layui.util;
|
||||
|
||||
loadList();
|
||||
toolbar();
|
||||
tableActionTool();
|
||||
search();
|
||||
|
||||
// 加载列表
|
||||
function loadList() {
|
||||
table.render({
|
||||
elem: '#tablelist',
|
||||
url: "/cache/list",
|
||||
method: "POST",
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
where: getQueryParams(),
|
||||
height: 'full',
|
||||
page: true,
|
||||
cols: [[
|
||||
{ field: 'name', title: '缓存键', align: 'left', width: 500 },
|
||||
{ title: '操作', toolbar: '#actionBox', align: 'center', width: 100 },
|
||||
]],
|
||||
skin: 'line',
|
||||
toolbar: '#toolbar',
|
||||
defaultToolbar: [{
|
||||
title: '刷新',
|
||||
layEvent: 'refresh',
|
||||
icon: 'layui-icon-refresh',
|
||||
}, 'filter', 'exports'],
|
||||
request: {
|
||||
pageName: 'page',
|
||||
limitName: 'rows'
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// 工具栏
|
||||
function toolbar() {
|
||||
table.on('toolbar(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
// case 'add': add(); break;
|
||||
case 'refresh': refresh(); break;
|
||||
}
|
||||
});
|
||||
|
||||
function add(obj) {
|
||||
layer.open({
|
||||
type: 2,
|
||||
title: '新增',
|
||||
shade: 0.1,
|
||||
area: ['95%', '95%'],
|
||||
content: "/riddle/add"
|
||||
});
|
||||
}
|
||||
|
||||
function refresh() {
|
||||
table.reload('tablelist');
|
||||
}
|
||||
}
|
||||
|
||||
// 表格项操作按钮
|
||||
function tableActionTool() {
|
||||
table.on('tool(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'refresh': refresh(obj); break;
|
||||
}
|
||||
});
|
||||
|
||||
function refresh(obj) {
|
||||
layer.confirm('确定要刷新缓存吗?', {
|
||||
icon: 3,
|
||||
title: '提示'
|
||||
}, function (index) {
|
||||
layer.close(index);
|
||||
$.ajax({
|
||||
url: "/cache/refresh",
|
||||
type: "POST",
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
data: {
|
||||
name: obj.data['name']
|
||||
},
|
||||
success: function (res) {
|
||||
layer.msg(res.msg, {
|
||||
icon: 1,
|
||||
time: 1000
|
||||
}, function () {
|
||||
table.reload('tablelist');
|
||||
});
|
||||
},
|
||||
error: function (res) {
|
||||
layer.msg(res.msg, {
|
||||
icon: 2,
|
||||
time: 1000
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
// layer.open({
|
||||
// type: 2,
|
||||
// title: '修改',
|
||||
// shade: 0.1,
|
||||
// area: ['95%', '95%'],
|
||||
// content: "/cache/refresh?keyword=" + obj.data['name']
|
||||
// });
|
||||
}
|
||||
}
|
||||
|
||||
// 搜索条件
|
||||
function getQueryParams() {
|
||||
return {
|
||||
title: $('#title').val()
|
||||
};
|
||||
}
|
||||
|
||||
// 搜索
|
||||
function search() {
|
||||
form.on('submit(user-query)', function (data) {
|
||||
table.reload('tablelist', {
|
||||
where: getQueryParams(),
|
||||
page: {
|
||||
curr: 1
|
||||
}
|
||||
})
|
||||
return false;
|
||||
});
|
||||
}
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
@@ -1,184 +0,0 @@
|
||||
{{template "header"}}
|
||||
|
||||
<div class="layui-body layui-bg-gray">
|
||||
<div class="layui-card">
|
||||
<form class="layui-form">
|
||||
{{.CsrfTokenField}}
|
||||
<input type="hidden" id="ID" name="ID" value="{{.Item.ID}}" />
|
||||
|
||||
<div class="layui-tab layui-tab-card" style="margin-bottom: 55px;">
|
||||
<ul class="layui-tab-title">
|
||||
<li class="layui-this">基础信息</li>
|
||||
<li>其它</li>
|
||||
</ul>
|
||||
|
||||
<div class="layui-tab-content">
|
||||
<div class="layui-tab-item layui-show">
|
||||
{{if .Item.ID}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">ID</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.ID}}
|
||||
</div>
|
||||
</div>
|
||||
{{end}}
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">名称</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="Name" name="Name" value="{{.Item.Name}}" lay-verify="required"
|
||||
autocomplete="off" placeholder="请输入名称" class="layui-input" style="width:700px;" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">联系人姓名</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="ContactName" name="ContactName" value="{{.Item.ContactName}}"
|
||||
autocomplete="off" placeholder="请输入联系人姓名" class="layui-input" />
|
||||
</div>
|
||||
<label class="layui-form-label">联系人手机</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="ContactPhone" name="ContactPhone" value="{{.Item.ContactPhone}}"
|
||||
autocomplete="off" placeholder="请输入联系人姓名" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">类别</label>
|
||||
<div class="layui-input-inline">
|
||||
<select id="Category" name="Category">
|
||||
{{range .Categories}}
|
||||
{{if .Selected}}
|
||||
<option value="{{.Value}}" selected>{{.Name}}</option>
|
||||
{{else}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
|
||||
<label class="layui-form-label">来源</label>
|
||||
<div class="layui-input-inline">
|
||||
<select id="Source" name="Source">
|
||||
{{range .Sources}}
|
||||
{{if .Selected}}
|
||||
<option value="{{.Value}}" selected>{{.Name}}</option>
|
||||
{{else}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">状态</label>
|
||||
<div class="layui-input-inline">
|
||||
<select id="Status" name="Status">
|
||||
{{range .Statuses}}
|
||||
{{if .Selected}}
|
||||
<option value="{{.Value}}" selected>{{.Name}}</option>
|
||||
{{else}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">地址</label>
|
||||
<div class="layui-input-inline">
|
||||
<textarea id="Address" name="Address" class="layui-textarea"
|
||||
style="width: 600px; height: 60px;">{{.Item.Address}}</textarea>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-tab-item">
|
||||
{{if .Item.ID}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">创建时间/人</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{dateFormat .Item.CreatedAt}} / {{.CreatedName}}
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">更新时间/人</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{dateFormat .Item.UpdatedAt}} / {{.UpdatedName}}
|
||||
</div>
|
||||
</div>
|
||||
{{end}}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item layui-fixbar btn-fixbar-box">
|
||||
<div class="layui-input-block">
|
||||
{{ submitBtn .AuthorizeMenus "save"}}
|
||||
<button type="button" class="layui-btn layui-btn-primary layui-btn-sm" lay-on="close">
|
||||
<i class="layui-icon layui-icon-close"></i>关闭
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
{{define "css"}}
|
||||
<style>
|
||||
.layui-body {
|
||||
padding: 15px;
|
||||
left: 0;
|
||||
}
|
||||
|
||||
.loader::after {
|
||||
content: '';
|
||||
}
|
||||
</style>
|
||||
{{end}}
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['form', 'jquery', 'iconPicker', 'dtree', 'xmSelect', "util"], function () {
|
||||
let form = layui.form;
|
||||
let $ = layui.jquery;
|
||||
let iconPicker = layui.iconPicker;
|
||||
let dtree = layui.dtree;
|
||||
let xmSelect = layui.xmSelect;
|
||||
let util = layui.util;
|
||||
|
||||
// 表单提交
|
||||
form.on('submit(save)', function (data) {
|
||||
$.ajax({
|
||||
url: '/customer/save',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
data: data.field,
|
||||
success: function (result) {
|
||||
if (result.success) {
|
||||
layer.msg(result.msg, { icon: 1, time: 1000 }, function () {
|
||||
parent.layer.close(parent.layer.getFrameIndex(window.name)); // 关闭当前页
|
||||
parent.layui.table.reload("tablelist", {
|
||||
page: { curr: 1 },
|
||||
});
|
||||
});
|
||||
} else {
|
||||
parent.layer.msg(result.msg, { icon: 2 })
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
return false;
|
||||
});
|
||||
|
||||
// 事件绑定
|
||||
util.on("lay-on", {
|
||||
"close": function () {
|
||||
window.parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
}
|
||||
});
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
@@ -1,350 +0,0 @@
|
||||
{{template "header" .}}
|
||||
|
||||
<!-- <div class="layui-row layui-col-space15">
|
||||
<div class="layui-collapse">
|
||||
<div class="layui-colla-item">
|
||||
<div class="layui-colla-title">查询</div>
|
||||
<div class="layui-colla-content layui-show">
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-body">
|
||||
<form class="layui-form layui-form-pane" action="">
|
||||
{{.CsrfTokenField}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-item layui-inline">
|
||||
<label class="layui-form-label" style="overflow:visible;padding:0;width:110px;">
|
||||
<select id="SearchTimeType">
|
||||
<option value="CreateTime">创建时间</option>
|
||||
</select>
|
||||
</label>
|
||||
<div class="layui-input-inline" style="width:150px;">
|
||||
<input type="text" class="layui-input" id="timeBegin" placeholder="yyyy-MM-dd"
|
||||
readonly value="{{ yearBegin }}" />
|
||||
</div>
|
||||
<div class="layui-input-inline"
|
||||
style="width:10px;line-height:30px;margin-right:5px">
|
||||
-
|
||||
</div>
|
||||
<div class="layui-input-inline" style="width:150px;">
|
||||
<input type="text" class="layui-input " id="timeEnd" placeholder="yyyy-MM-dd"
|
||||
readonly value="{{ monthEnd }}" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item layui-inline">
|
||||
<label class="layui-form-label">
|
||||
状态
|
||||
</label>
|
||||
<div class="layui-input-inline">
|
||||
<select id="status">
|
||||
<option value="0">请选择</option>
|
||||
{{range .Statuses}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item layui-inline">
|
||||
<label class="layui-form-label">
|
||||
类别
|
||||
</label>
|
||||
<div class="layui-input-inline">
|
||||
<select id="category">
|
||||
{{range.Categories}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item layui-inline">
|
||||
<label class="layui-form-label">
|
||||
来源
|
||||
</label>
|
||||
<div class="layui-input-inline">
|
||||
<select id="source">
|
||||
{{range.Sources}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-inline">
|
||||
<input type="text" id="title" placeholder="" class="layui-input">
|
||||
</div>
|
||||
<div class="layui-inline">
|
||||
<button type="button" class="pear-btn pear-btn-md pear-btn-primary" lay-submit
|
||||
lay-filter="user-query">
|
||||
<i class="layui-icon layui-icon-search"></i>
|
||||
查询
|
||||
</button>
|
||||
<button type="reset" class="pear-btn pear-btn-md" lay-submit
|
||||
lay-filter="user-reset">
|
||||
<i class="layui-icon layui-icon-refresh"></i>
|
||||
重置
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div> -->
|
||||
|
||||
<!-- 工具栏 -->
|
||||
<script id="toolbar" type="text/html">
|
||||
{{ genBtn .AuthorizeMenus "add"}}
|
||||
<button type="button" lay-event="search" lay-on="search" class="layui-btn layui-btn-primary layui-btn-sm">
|
||||
<i class="layui-icon layui-icon-search"></i>
|
||||
</button>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="actionBox">
|
||||
{{ genLink .AuthorizeMenus "edit"}}
|
||||
</script>
|
||||
|
||||
<div class="search-layer" id="search-layer" style="display: none;">
|
||||
<div class="layui-form layui-row">
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">开始时间</label>
|
||||
<input type="text" name="timeBegin" id="timeBegin" placeholder="yyyy-MM-dd" readonly
|
||||
value="{{ yearBegin }}" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">结束时间</label>
|
||||
<input type="text" name="timeEnd" id="timeEnd" placeholder="yyyy-MM-dd" readonly value="{{ monthEnd }}"
|
||||
class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">状态</label>
|
||||
<select name="status" id="status">
|
||||
{{range.Statuses}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form layui-row">
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">类别</label>
|
||||
<select id="category" name="category">
|
||||
{{range.Categories}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">来源</label>
|
||||
<select id="source">
|
||||
{{range.Sources}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">名称</label>
|
||||
<input type="text" name="title" id="title" placeholder="请输入名称" autocomplete="off" class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-panel">
|
||||
<table id="tablelist" lay-filter="tablelist"></table>
|
||||
</div>
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['table', 'form', 'jquery', 'laydate', 'util'], function () {
|
||||
let table = layui.table;
|
||||
let form = layui.form;
|
||||
let $ = layui.jquery;
|
||||
let util = layui.util;
|
||||
let laydate = layui.laydate;
|
||||
|
||||
/**开始时间 */
|
||||
laydate.render({
|
||||
elem: '#timeBegin',
|
||||
type: 'datetime',
|
||||
value: '{{ yearBegin }}',
|
||||
ready: function (date) {
|
||||
this.dateTime.hours = 0;
|
||||
this.dateTime.minutes = 0;
|
||||
this.dateTime.seconds = 0;
|
||||
}
|
||||
});
|
||||
|
||||
/**截止时间 */
|
||||
laydate.render({
|
||||
elem: '#timeEnd',
|
||||
type: 'datetime',
|
||||
value: '{{ monthEnd }}',
|
||||
ready: function (date) {
|
||||
this.dateTime.hours = 23;
|
||||
this.dateTime.minutes = 59;
|
||||
this.dateTime.seconds = 59;
|
||||
}
|
||||
});
|
||||
|
||||
// 加载列表
|
||||
table.render({
|
||||
elem: '#tablelist',
|
||||
url: "/customer/list",
|
||||
method: "POST",
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
where: getQueryParams(),
|
||||
// height: 'full-100',
|
||||
height: function () {
|
||||
return $(window).height() - 22;
|
||||
},
|
||||
page: true,
|
||||
cols: [[
|
||||
{ field: 'name', title: '名称', align: 'left', fixed: 'left', width: 200 },
|
||||
{ field: 'sid', title: '编号', align: 'left', width: 180 },
|
||||
{ field: 'category_name', title: '类别', align: 'left', width: 100 },
|
||||
{ field: 'source_name', title: '来源', align: 'left', width: 100 },
|
||||
{
|
||||
field: 'status', title: '状态', align: 'center', width: 90, templet: function (row) {
|
||||
switch (row.status) {
|
||||
case 0: return '<span style="color:green;">正常</span>';
|
||||
case -1: return '<span style="color:red;">删除</span>';
|
||||
default: return '其它';
|
||||
}
|
||||
return '';
|
||||
}
|
||||
},
|
||||
{ field: 'contact_name', title: '联系人姓名', align: 'left', width: 120 },
|
||||
{ field: 'contact_phone', title: '联系人手机', align: 'left', width: 120 },
|
||||
{ field: 'address', title: '地址', align: 'left', width: 200 },
|
||||
{ field: 'sort', title: '排序', align: 'center', width: 80 },
|
||||
{ field: 'created_at', title: '创建时间', align: 'center', width: 160, templet: function (d) { return !d.created_at ? '' : util.toDateString(d.created_at) } },
|
||||
{ field: 'created_name', title: '创建人', align: 'center', width: 100 },
|
||||
{ field: 'updated_at', title: '更新时间', align: 'center', width: 160, templet: function (d) { return !d.updated_at ? '' : util.toDateString(d.updated_at) } },
|
||||
{ field: 'updated_name', title: '更新人', align: 'center', width: 100 },
|
||||
{ title: '操作', toolbar: '#actionBox', align: 'center', fixed: 'right', width: 100 },
|
||||
]],
|
||||
skin: 'line',
|
||||
toolbar: '#toolbar',
|
||||
defaultToolbar: [{
|
||||
title: '刷新',
|
||||
layEvent: 'refresh',
|
||||
icon: 'layui-icon-refresh',
|
||||
}, 'filter', 'exports'],
|
||||
request: {
|
||||
pageName: 'page',
|
||||
limitName: 'rows'
|
||||
}
|
||||
});
|
||||
|
||||
// 工具栏
|
||||
table.on('toolbar(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'add': add(); break;
|
||||
case 'search': search(); break;
|
||||
case 'refresh': refresh(); break;
|
||||
}
|
||||
});
|
||||
|
||||
function add(obj) {
|
||||
layer.open({
|
||||
type: 2,
|
||||
// offset: 'r',
|
||||
// anim: 'slideLeft',
|
||||
title: '新增',
|
||||
shade: 0.1,
|
||||
area: ['99%', '98%'],
|
||||
content: "/customer/add"
|
||||
});
|
||||
}
|
||||
|
||||
function search() {
|
||||
layer.open({
|
||||
type: 1,
|
||||
offset: '20px',
|
||||
title: '搜索',
|
||||
content: $('#search-layer'), // 捕获的元素
|
||||
shade: 0.1,
|
||||
shadeClose: false,
|
||||
scrollbar: false,
|
||||
resize: false,
|
||||
move: false,
|
||||
skin: 'search-layer-open',
|
||||
area: ['50%', '350px'],
|
||||
btn: ['搜索', '重置'],
|
||||
btn1: function (index, layero) {
|
||||
search_btn();
|
||||
layer.close(index);
|
||||
},
|
||||
btn2: function (index, layero) {
|
||||
$('#timeBegin').val(formatDate(getCurrentYearStart(), 'YYYY-MM-DD HH:mm:ss'));
|
||||
$('#timeEnd').val(formatDate(getCurrentMonthEnd(), 'YYYY-MM-DD HH:mm:ss'));
|
||||
$('#title').val('');
|
||||
$('#category').val('');
|
||||
$('#source').val('');
|
||||
$('#status').val(9999);
|
||||
form.render('select');
|
||||
return false;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function refresh() {
|
||||
table.reload('tablelist');
|
||||
}
|
||||
|
||||
// 表格项操作按钮
|
||||
table.on('tool(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'edit': edit(obj); break;
|
||||
}
|
||||
});
|
||||
|
||||
function edit(obj) {
|
||||
layer.open({
|
||||
type: 2,
|
||||
// offset: 'r',
|
||||
// anim: 'slideLeft',
|
||||
title: '修改',
|
||||
shade: 0.1,
|
||||
area: ['99%', '98%'],
|
||||
content: "/customer/edit?id=" + obj.data['sid']
|
||||
});
|
||||
}
|
||||
|
||||
// 搜索条件
|
||||
function getQueryParams() {
|
||||
return {
|
||||
timeBegin: $('#timeBegin').val(),
|
||||
timeEnd: $('#timeEnd').val(),
|
||||
status: $('#status').val(),
|
||||
category: $('#category').val(),
|
||||
source: $('#source').val(),
|
||||
title: $('#title').val()
|
||||
};
|
||||
}
|
||||
|
||||
// 搜索
|
||||
function search_btn() {
|
||||
table.reload('tablelist', {
|
||||
where: getQueryParams(),
|
||||
page: {
|
||||
curr: 1
|
||||
}
|
||||
})
|
||||
return false;
|
||||
}
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
@@ -1,269 +0,0 @@
|
||||
{{template "header"}}
|
||||
|
||||
<form class="layui-form" style="padding-bottom: 80px;">
|
||||
{{.CsrfTokenField}}
|
||||
<input type="hidden" id="ID" name="ID" value="{{.Item.ID}}" />
|
||||
|
||||
<div class="layui-tab-content" style="padding-top: 0;">
|
||||
<div class="layui-tab-item layui-show">
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">项目信息</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">选择项目</div>
|
||||
<div class="layui-input-inline" id="ProjectID" style="width: 240px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">预算信息</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">选择预算</div>
|
||||
<div class="layui-input-inline" id="BudgetID" style="width: 240px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">报销信息</div>
|
||||
<div class="layui-card-body">
|
||||
{{if .Item.ID}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">编号</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.ID}}
|
||||
</div>
|
||||
</div>
|
||||
{{end}}
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">报销类别</label>
|
||||
<div class="layui-input-inline" id="ExpensesType" style="width: 240px;"></div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">报销时间</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="ExpensesAt" name="ExpensesAt" value="{{.Item.ExpensesAt}}"
|
||||
lay-verify="required" autocomplete="off" placeholder="请输入名称" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">报销金额</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="Amount" name="Amount" value="{{.Item.Amount}}" lay-verify="required"
|
||||
autocomplete="off" placeholder="请输入预算金额" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">其他</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">状态</label>
|
||||
<div class="layui-input-inline">
|
||||
<select id="Status" name="Status">
|
||||
{{range .Statuses}}
|
||||
{{if .Selected}}
|
||||
<option value="{{.Value}}" selected>{{.Name}}</option>
|
||||
{{else}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
{{if .Item.ID}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">创建</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.CreatedName}}
|
||||
({{dateFormat .Item.CreatedAt}})
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">更新</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.UpdatedName}}
|
||||
({{dateFormat .Item.UpdatedAt}})
|
||||
</div>
|
||||
</div>
|
||||
{{end}}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item layui-fixbar btn-fixbar-box">
|
||||
<div class="layui-input-block">
|
||||
{{ submitBtn .AuthorizeMenus "save"}}
|
||||
<button type="button" class="layui-btn layui-btn-primary layui-btn-sm" lay-on="close">
|
||||
<i class="layui-icon layui-icon-close"></i>关闭
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</form>
|
||||
|
||||
{{define "css"}}
|
||||
<style>
|
||||
.layui-body {
|
||||
padding: 15px;
|
||||
left: 0;
|
||||
}
|
||||
|
||||
.loader::after {
|
||||
content: '';
|
||||
}
|
||||
</style>
|
||||
{{end}}
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['jquery', 'form', 'laydate', 'xmSelect', "util"], function () {
|
||||
let $ = layui.jquery;
|
||||
let form = layui.form;
|
||||
let xmSelect = layui.xmSelect;
|
||||
let util = layui.util;
|
||||
let laydate = layui.laydate;
|
||||
|
||||
laydate.render({
|
||||
elem: '#ExpensesAt',
|
||||
type: 'date',
|
||||
value: '{{today}}',
|
||||
});
|
||||
|
||||
// 表单提交
|
||||
form.on('submit(save)', function (data) {
|
||||
$.ajax({
|
||||
url: '/expense/save',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
data: data.field,
|
||||
success: function (result) {
|
||||
if (result.success) {
|
||||
layer.msg(result.msg, { icon: 1, time: 1000 }, function () {
|
||||
parent.layer.close(parent.layer.getFrameIndex(window.name)); // 关闭当前页
|
||||
parent.layui.table.reload("tablelist", {
|
||||
page: { curr: 1 },
|
||||
});
|
||||
});
|
||||
} else {
|
||||
parent.layer.msg(result.msg, { icon: 2 })
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
return false;
|
||||
});
|
||||
|
||||
// 事件绑定
|
||||
util.on("lay-on", {
|
||||
"close": function () {
|
||||
window.parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
}
|
||||
});
|
||||
|
||||
getProject();
|
||||
getBudget('{{.Item.ProjectID}}');
|
||||
getCategory();
|
||||
|
||||
function getProject() {
|
||||
$.ajax({
|
||||
url: '/project/data?type=xmselect',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
success: function (res) {
|
||||
xmSelect.render({
|
||||
el: '#ProjectID',
|
||||
// 工具栏
|
||||
radio: true,
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择项目',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'ProjectID',
|
||||
initValue: ['{{.Item.ProjectID}}'],
|
||||
on: function (data) {
|
||||
console.log(data);
|
||||
console.log(data.arr[0].value);
|
||||
getBudget(data.arr[0].value);
|
||||
},
|
||||
});
|
||||
},
|
||||
error: function (err) {
|
||||
// 处理请求错误
|
||||
console.log('请求出错:', err);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function getBudget(projectId) {
|
||||
$.ajax({
|
||||
url: '/budget/data?type=xmselect&projectId=' + projectId,
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
success: function (res) {
|
||||
xmSelect.render({
|
||||
el: '#BudgetID',
|
||||
// 工具栏
|
||||
radio: true,
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择项目预算',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'BudgetID',
|
||||
initValue: ['{{.Item.BudgetID}}'],
|
||||
on: function (data) {
|
||||
console.log(data);
|
||||
},
|
||||
});
|
||||
},
|
||||
error: function (err) {
|
||||
// 处理请求错误
|
||||
console.log('请求出错:', err);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function getCategory() {
|
||||
$.ajax({
|
||||
url: '/system/category/data?type=xmselect&letter=expense_category',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
success: function (res) {
|
||||
xmSelect.render({
|
||||
el: '#ExpensesType',
|
||||
// 工具栏
|
||||
radio: true,
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择预算类别',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'ExpensesType',
|
||||
initValue: ['{{.Item.ExpensesType}}'],
|
||||
on: function (data) { },
|
||||
});
|
||||
},
|
||||
error: function (err) {
|
||||
// 处理请求错误
|
||||
console.log('请求出错:', err);
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
@@ -1,231 +0,0 @@
|
||||
{{template "header" .}}
|
||||
|
||||
<!-- 工具栏 -->
|
||||
<script id="toolbar" type="text/html">
|
||||
{{ genBtn .AuthorizeMenus "add"}}
|
||||
<button type="button" lay-event="search" lay-on="search" class="layui-btn layui-btn-primary layui-btn-sm">
|
||||
<i class="layui-icon layui-icon-search"></i>
|
||||
</button>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="actionBox">
|
||||
{{ genLink .AuthorizeMenus "edit"}}
|
||||
</script>
|
||||
|
||||
<div class="search-layer" id="search-layer" style="display: none;">
|
||||
<div class="layui-form layui-row">
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">开始时间</label>
|
||||
<input type="text" name="timeBegin" id="timeBegin" placeholder="yyyy-MM-dd" readonly
|
||||
value="{{ yearBegin }}" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">结束时间</label>
|
||||
<input type="text" name="timeEnd" id="timeEnd" placeholder="yyyy-MM-dd" readonly value="{{ monthEnd }}"
|
||||
class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">项目</label>
|
||||
<select id="project">
|
||||
{{range.Projects}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form layui-row">
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">类别</label>
|
||||
<select id="category">
|
||||
{{range.Categories}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">项目状态</label>
|
||||
<select name="status" id="status">
|
||||
<option value="9999">请选择</option>
|
||||
{{range.Statuses}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-panel">
|
||||
<table id="tablelist" lay-filter="tablelist"></table>
|
||||
</div>
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['jquery', 'table', 'form', 'laydate', 'util'], function () {
|
||||
let $ = layui.jquery;
|
||||
let table = layui.table;
|
||||
let form = layui.form;
|
||||
let util = layui.util;
|
||||
let laydate = layui.laydate;
|
||||
|
||||
// 加载列表
|
||||
table.render({
|
||||
elem: '#tablelist',
|
||||
url: "/expense/list",
|
||||
method: "POST",
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
where: getQueryParams(),
|
||||
height: function () {
|
||||
return $(window).height() - 22;
|
||||
},
|
||||
page: true,
|
||||
limit: 15,
|
||||
limits: [15, 30, 45, 60, 75, 90],
|
||||
cols: [[
|
||||
{ field: 'id', title: '报销编号', align: 'left', fixed: 'left', width: 100 },
|
||||
{ field: 'project_name', title: '关联项目', align: 'left', width: 200 },
|
||||
{ field: 'project_id', title: '项目编号', align: 'left', width: 200 },
|
||||
{ field: 'budget_name', title: '关联预算', align: 'left', width: 200 },
|
||||
{ field: 'budget_id', title: '预算编号', align: 'left', width: 200 },
|
||||
{ field: 'expenses_type_name', title: '报销类别', align: 'left', width: 100 },
|
||||
{ field: 'expenses_at', title: '报销时间', align: 'left', width: 160, templet: function (d) { return !d.expenses_at ? '' : util.toDateString(d.expenses_at) } },
|
||||
{ field: 'amount', title: '报销金额', align: 'left', width: 120 },
|
||||
{
|
||||
field: 'status', title: '状态', align: 'center', width: 90, templet: function (row) {
|
||||
switch (row.status) {
|
||||
case 0: return '<span style="color:green;">正常</span>';
|
||||
case -1: return '<span style="color:red;">删除</span>';
|
||||
default: return '其它';
|
||||
}
|
||||
return '';
|
||||
}
|
||||
},
|
||||
{ field: 'created_at', title: '创建时间', align: 'center', width: 160, templet: function (d) { return !d.created_at ? '' : util.toDateString(d.created_at) } },
|
||||
{ field: 'created_name', title: '创建人', align: 'center', width: 100 },
|
||||
{ field: 'updated_at', title: '更新时间', align: 'center', width: 160, templet: function (d) { return !d.updated_at ? '' : util.toDateString(d.updated_at) } },
|
||||
{ field: 'updated_name', title: '更新人', align: 'center', width: 100 },
|
||||
{ title: '操作', toolbar: '#actionBox', align: 'center', fixed: 'right', width: 100 },
|
||||
]],
|
||||
skin: 'line',
|
||||
toolbar: '#toolbar',
|
||||
defaultToolbar: [{
|
||||
title: '刷新',
|
||||
layEvent: 'refresh',
|
||||
icon: 'layui-icon-refresh',
|
||||
}, 'filter', 'exports'],
|
||||
request: {
|
||||
pageName: 'page',
|
||||
limitName: 'rows'
|
||||
}
|
||||
});
|
||||
|
||||
// 工具栏
|
||||
table.on('toolbar(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'add': add(); break;
|
||||
case 'search': search(); break;
|
||||
case 'refresh': refresh(); break;
|
||||
}
|
||||
});
|
||||
|
||||
function add(obj) {
|
||||
layer.open({
|
||||
type: 2,
|
||||
// offset: 'r',
|
||||
// anim: 'slideLeft',
|
||||
title: '新增',
|
||||
shade: 0.1,
|
||||
area: ['99%', '98%'],
|
||||
content: "/expense/add"
|
||||
});
|
||||
}
|
||||
|
||||
function search() {
|
||||
layer.open({
|
||||
type: 1,
|
||||
offset: '20px',
|
||||
title: '搜索',
|
||||
content: $('#search-layer'), // 捕获的元素
|
||||
shade: 0.1,
|
||||
shadeClose: false,
|
||||
scrollbar: false,
|
||||
resize: false,
|
||||
move: false,
|
||||
skin: 'search-layer-open',
|
||||
area: ['50%', '350px'],
|
||||
btn: ['搜索', '重置'],
|
||||
btn1: function (index, layero) {
|
||||
search_btn();
|
||||
layer.close(index);
|
||||
},
|
||||
btn2: function (index, layero) {
|
||||
$('#timeBegin').val(formatDate(getCurrentYearStart(), 'YYYY-MM-DD HH:mm:ss'));
|
||||
$('#timeEnd').val(formatDate(getCurrentMonthEnd(), 'YYYY-MM-DD HH:mm:ss'));
|
||||
$('#title').val('');
|
||||
$('#sid').val('');
|
||||
$('#customer_name').val('');
|
||||
$('#status').val(9999);
|
||||
form.render('select');
|
||||
return false;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function refresh() {
|
||||
table.reload('tablelist');
|
||||
}
|
||||
|
||||
// 表格项操作按钮
|
||||
table.on('tool(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'edit': edit(obj); break;
|
||||
}
|
||||
});
|
||||
|
||||
function edit(obj) {
|
||||
layer.open({
|
||||
type: 2,
|
||||
// offset: 'r',
|
||||
// anim: 'slideLeft',
|
||||
title: '修改',
|
||||
shade: 0.1,
|
||||
area: ['99%', '98%'],
|
||||
content: "/expense/edit?id=" + obj.data['id']
|
||||
});
|
||||
}
|
||||
|
||||
// 搜索条件
|
||||
function getQueryParams() {
|
||||
return {
|
||||
timeBegin: $('#timeBegin').val(),
|
||||
timeEnd: $('#timeEnd').val(),
|
||||
status: $('#status').val(),
|
||||
category: $('#category').val(),
|
||||
project: $('#project').val(),
|
||||
title: $('#title').val()
|
||||
};
|
||||
}
|
||||
|
||||
// 搜索
|
||||
function search_btn() {
|
||||
table.reload('tablelist', {
|
||||
where: getQueryParams(),
|
||||
page: {
|
||||
curr: 1
|
||||
}
|
||||
})
|
||||
}
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
@@ -80,7 +80,7 @@
|
||||
</div>
|
||||
</div>
|
||||
<!-- 视 图 页 面 -->
|
||||
<div class="layui-body">
|
||||
<div class="layui-body" style="padding: 0">
|
||||
<!-- 内 容 页 面 -->
|
||||
<div id="content"></div>
|
||||
</div>
|
||||
@@ -103,9 +103,9 @@
|
||||
<script src="/statics/component/pear/pear.js"></script>
|
||||
<script>
|
||||
layui.use(['admin', 'jquery', 'popup', 'drawer'], function () {
|
||||
var $ = layui.jquery;
|
||||
var admin = layui.admin;
|
||||
var popup = layui.popup;
|
||||
const $ = layui.jquery;
|
||||
const admin = layui.admin;
|
||||
const popup = layui.popup;
|
||||
|
||||
// yml | json | api
|
||||
admin.setConfigurationPath("/pear.json");
|
||||
|
||||
@@ -1,310 +0,0 @@
|
||||
{{template "header"}}
|
||||
|
||||
<form class="layui-form" style="padding-bottom: 80px;">
|
||||
{{.CsrfTokenField}}
|
||||
<input type="hidden" id="ID" name="ID" value="{{.Item.ID}}" />
|
||||
|
||||
<div class="layui-tab-content" style="padding-top: 0;">
|
||||
<div class="layui-tab-item layui-show">
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">项目信息</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">选择项目</div>
|
||||
<div class="layui-input-inline" id="ProjectID" style="width: 240px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">预算信息</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">选择预算</div>
|
||||
<div class="layui-input-inline" id="BudgetID" style="width: 240px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">收入信息</div>
|
||||
<div class="layui-card-body">
|
||||
{{if .Item.ID}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">编号</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.ID}}
|
||||
</div>
|
||||
</div>
|
||||
{{end}}
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">收入类别</label>
|
||||
<div class="layui-input-inline" id="IncomeType" style="width: 240px;"></div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">收入银行</label>
|
||||
<div class="layui-input-inline" id="IncomeBank" style="width: 240px;"></div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">收入时间</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="IncomeAt" name="IncomeAt" value="{{.Item.IncomeAt}}"
|
||||
lay-verify="required" autocomplete="off" placeholder="请输入收入时间" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">收入金额</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="Amount" name="Amount" value="{{.Item.Amount}}" lay-verify="required"
|
||||
autocomplete="off" placeholder="请输入收入金额" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">备注</label>
|
||||
<div class="layui-input-inline">
|
||||
<textarea id="Remark" name="Remark" class="layui-textarea"
|
||||
style="width: 600px; height: 60px;">{{.Item.Remark}}</textarea>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">其他</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">状态</label>
|
||||
<div class="layui-input-inline">
|
||||
<select id="Status" name="Status">
|
||||
{{range .Statuses}}
|
||||
{{if .Selected}}
|
||||
<option value="{{.Value}}" selected>{{.Name}}</option>
|
||||
{{else}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
{{if .Item.ID}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">创建</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.CreatedName}}
|
||||
({{dateFormat .Item.CreatedAt}})
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">更新</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.UpdatedName}}
|
||||
({{dateFormat .Item.UpdatedAt}})
|
||||
</div>
|
||||
</div>
|
||||
{{end}}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item layui-fixbar btn-fixbar-box">
|
||||
<div class="layui-input-block">
|
||||
{{ submitBtn .AuthorizeMenus "save"}}
|
||||
<button type="button" class="layui-btn layui-btn-primary layui-btn-sm" lay-on="close">
|
||||
<i class="layui-icon layui-icon-close"></i>关闭
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</form>
|
||||
|
||||
{{define "css"}}
|
||||
<style>
|
||||
.layui-body {
|
||||
padding: 15px;
|
||||
left: 0;
|
||||
}
|
||||
|
||||
.loader::after {
|
||||
content: '';
|
||||
}
|
||||
</style>
|
||||
{{end}}
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['jquery', 'form', 'laydate', 'xmSelect', "util"], function () {
|
||||
let $ = layui.jquery;
|
||||
let form = layui.form;
|
||||
let laydate = layui.laydate;
|
||||
let xmSelect = layui.xmSelect;
|
||||
let util = layui.util;
|
||||
|
||||
laydate.render({
|
||||
elem: '#IncomeAt',
|
||||
type: 'date',
|
||||
value: '{{today}}',
|
||||
});
|
||||
|
||||
// 表单提交
|
||||
form.on('submit(save)', function (data) {
|
||||
$.ajax({
|
||||
url: '/income/save',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
data: data.field,
|
||||
success: function (result) {
|
||||
if (result.success) {
|
||||
layer.msg(result.msg, { icon: 1, time: 1000 }, function () {
|
||||
parent.layer.close(parent.layer.getFrameIndex(window.name)); // 关闭当前页
|
||||
parent.layui.table.reload("tablelist", {
|
||||
page: { curr: 1 },
|
||||
});
|
||||
});
|
||||
} else {
|
||||
parent.layer.msg(result.msg, { icon: 2 })
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
return false;
|
||||
});
|
||||
|
||||
// 事件绑定
|
||||
util.on("lay-on", {
|
||||
"close": function () {
|
||||
window.parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
}
|
||||
});
|
||||
|
||||
getProject();
|
||||
getBudget('{{.Item.ProjectID}}');
|
||||
getIncomeType();
|
||||
getIncomeBank();
|
||||
|
||||
function getProject() {
|
||||
$.ajax({
|
||||
url: '/project/data?type=xmselect',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
success: function (res) {
|
||||
xmSelect.render({
|
||||
el: '#ProjectID',
|
||||
// 工具栏
|
||||
radio: true,
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择项目',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'ProjectID',
|
||||
initValue: ['{{.Item.ProjectID}}'],
|
||||
on: function (data) {
|
||||
console.log(data);
|
||||
console.log(data.arr[0].value);
|
||||
getBudget(data.arr[0].value);
|
||||
},
|
||||
});
|
||||
},
|
||||
error: function (err) {
|
||||
// 处理请求错误
|
||||
console.log('请求出错:', err);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function getBudget(projectId) {
|
||||
$.ajax({
|
||||
url: '/budget/xmselect?projectId=' + projectId,
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
success: function (res) {
|
||||
xmSelect.render({
|
||||
el: '#BudgetID',
|
||||
// 工具栏
|
||||
radio: true,
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择项目预算',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'BudgetID',
|
||||
initValue: ['{{.Item.BudgetID}}'],
|
||||
on: function (data) {
|
||||
console.log(data);
|
||||
},
|
||||
});
|
||||
},
|
||||
error: function (err) {
|
||||
// 处理请求错误
|
||||
console.log('请求出错:', err);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function getIncomeType() {
|
||||
$.ajax({
|
||||
url: '/system/category/data?type=xmselect&letter=income_category',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
success: function (res) {
|
||||
xmSelect.render({
|
||||
el: '#IncomeType',
|
||||
// 工具栏
|
||||
radio: true,
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择收入类别',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'IncomeType',
|
||||
initValue: ['{{.Item.IncomeType}}'],
|
||||
on: function (data) { },
|
||||
});
|
||||
},
|
||||
error: function (err) {
|
||||
// 处理请求错误
|
||||
console.log('请求出错:', err);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function getIncomeBank() {
|
||||
$.ajax({
|
||||
url: '/system/category/data?type=xmselect&letter=income_bank',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
success: function (res) {
|
||||
xmSelect.render({
|
||||
el: '#IncomeBank',
|
||||
// 工具栏
|
||||
radio: true,
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择收入银行',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'IncomeBank',
|
||||
initValue: ['{{.Item.IncomeBank}}'],
|
||||
on: function (data) { },
|
||||
});
|
||||
},
|
||||
error: function (err) {
|
||||
// 处理请求错误
|
||||
console.log('请求出错:', err);
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
@@ -1,254 +0,0 @@
|
||||
{{template "header" .}}
|
||||
|
||||
<script id="toolbar" type="text/html">
|
||||
{{ genBtn .AuthorizeMenus "add"}}
|
||||
<button type="button" lay-event="search" lay-on="search" class="layui-btn layui-btn-primary layui-btn-sm">
|
||||
<i class="layui-icon layui-icon-search"></i>
|
||||
</button>
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="actionBox">
|
||||
{{ genLink .AuthorizeMenus "edit"}}
|
||||
</script>
|
||||
|
||||
<div class="search-layer" id="search-layer" style="display: none;">
|
||||
<div class="layui-form layui-row">
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">开始时间</label>
|
||||
<input type="text" name="timeBegin" id="timeBegin" placeholder="yyyy-MM-dd" readonly
|
||||
value="{{ yearBegin }}" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">结束时间</label>
|
||||
<input type="text" name="timeEnd" id="timeEnd" placeholder="yyyy-MM-dd" readonly value="{{ monthEnd }}"
|
||||
class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">项目</label>
|
||||
<select id="project">
|
||||
{{range.Projects}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form layui-row">
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">类别</label>
|
||||
<select id="category">
|
||||
{{range.Categories}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">项目状态</label>
|
||||
<select name="status" id="status">
|
||||
<option value="9999">请选择</option>
|
||||
{{range.Statuses}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-panel">
|
||||
<table id="tablelist" lay-filter="tablelist"></table>
|
||||
</div>
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['jquery', 'table', 'form', 'laydate', 'util'], function () {
|
||||
let $ = layui.jquery;
|
||||
let table = layui.table;
|
||||
let form = layui.form;
|
||||
let util = layui.util;
|
||||
let laydate = layui.laydate;
|
||||
|
||||
/**开始时间 */
|
||||
laydate.render({
|
||||
elem: '#timeBegin',
|
||||
type: 'datetime',
|
||||
value: '{{ yearBegin }}',
|
||||
ready: function (date) {
|
||||
this.dateTime.hours = 0;
|
||||
this.dateTime.minutes = 0;
|
||||
this.dateTime.seconds = 0;
|
||||
}
|
||||
});
|
||||
|
||||
/**截止时间 */
|
||||
laydate.render({
|
||||
elem: '#timeEnd',
|
||||
type: 'datetime',
|
||||
value: '{{ monthEnd }}',
|
||||
ready: function (date) {
|
||||
this.dateTime.hours = 23;
|
||||
this.dateTime.minutes = 59;
|
||||
this.dateTime.seconds = 59;
|
||||
}
|
||||
});
|
||||
|
||||
table.render({
|
||||
elem: '#tablelist',
|
||||
url: "/income/list",
|
||||
method: "POST",
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
where: getQueryParams(),
|
||||
height: function () {
|
||||
return $(window).height() - 22;
|
||||
},
|
||||
page: true,
|
||||
limit: 15,
|
||||
limits: [15, 30, 45, 60, 75, 90],
|
||||
cols: [[
|
||||
{ field: 'id', title: '回款编号', align: 'left', fixed: 'left', width: 100 },
|
||||
{ field: 'project_name', title: '关联项目', align: 'left', width: 200 },
|
||||
{ field: 'project_id', title: '项目编号', align: 'left', width: 200 },
|
||||
{ field: 'budget_name', title: '关联预算', align: 'left', width: 200 },
|
||||
{ field: 'budget_id', title: '预算编号', align: 'left', width: 200 },
|
||||
{ field: 'income_type_name', title: '回款类别', align: 'left', width: 100 },
|
||||
{ field: 'income_at', title: '回款时间', align: 'left', width: 160, templet: function (d) { return !d.income_at ? '' : util.toDateString(d.income_at) } },
|
||||
{ field: 'amount', title: '回款金额', align: 'left', width: 120 },
|
||||
{
|
||||
field: 'status', title: '状态', align: 'center', width: 90, templet: function (row) {
|
||||
switch (row.status) {
|
||||
case 0: return '<span style="color:green;">正常</span>';
|
||||
case -1: return '<span style="color:red;">删除</span>';
|
||||
default: return '其它';
|
||||
}
|
||||
return '';
|
||||
}
|
||||
},
|
||||
{ field: 'created_at', title: '创建时间', align: 'center', width: 160, templet: function (d) { return !d.created_at ? '' : util.toDateString(d.created_at) } },
|
||||
{ field: 'created_name', title: '创建人', align: 'center', width: 100 },
|
||||
{ field: 'updated_at', title: '更新时间', align: 'center', width: 160, templet: function (d) { return !d.updated_at ? '' : util.toDateString(d.updated_at) } },
|
||||
{ field: 'updated_name', title: '更新人', align: 'center', width: 100 },
|
||||
{ title: '操作', toolbar: '#actionBox', align: 'center', fixed: 'right', width: 100 },
|
||||
]],
|
||||
skin: 'line',
|
||||
toolbar: '#toolbar',
|
||||
defaultToolbar: [{
|
||||
title: '刷新',
|
||||
layEvent: 'refresh',
|
||||
icon: 'layui-icon-refresh',
|
||||
}, 'filter', 'exports'],
|
||||
request: {
|
||||
pageName: 'page',
|
||||
limitName: 'rows'
|
||||
}
|
||||
});
|
||||
|
||||
// 工具栏
|
||||
table.on('toolbar(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'add': add(); break;
|
||||
case 'search': search(); break;
|
||||
case 'refresh': refresh(); break;
|
||||
}
|
||||
});
|
||||
|
||||
function add(obj) {
|
||||
layer.open({
|
||||
type: 2,
|
||||
// offset: 'r',
|
||||
// anim: 'slideLeft',
|
||||
title: '新增',
|
||||
shade: 0.1,
|
||||
area: ['99%', '98%'],
|
||||
content: "/income/add"
|
||||
});
|
||||
}
|
||||
|
||||
function search() {
|
||||
layer.open({
|
||||
type: 1,
|
||||
offset: '20px',
|
||||
title: '搜索',
|
||||
content: $('#search-layer'), // 捕获的元素
|
||||
shade: 0.1,
|
||||
shadeClose: false,
|
||||
scrollbar: false,
|
||||
resize: false,
|
||||
move: false,
|
||||
skin: 'search-layer-open',
|
||||
area: ['50%', '350px'],
|
||||
btn: ['搜索', '重置'],
|
||||
btn1: function (index, layero) {
|
||||
search_btn();
|
||||
layer.close(index);
|
||||
},
|
||||
btn2: function (index, layero) {
|
||||
$('#timeBegin').val(formatDate(getCurrentYearStart(), 'YYYY-MM-DD HH:mm:ss'));
|
||||
$('#timeEnd').val(formatDate(getCurrentMonthEnd(), 'YYYY-MM-DD HH:mm:ss'));
|
||||
$('#title').val('');
|
||||
$('#sid').val('');
|
||||
$('#customer_name').val('');
|
||||
$('#status').val(9999);
|
||||
form.render('select');
|
||||
return false;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function refresh() {
|
||||
table.reload('tablelist');
|
||||
}
|
||||
|
||||
// 表格项操作按钮
|
||||
table.on('tool(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'edit': edit(obj); break;
|
||||
}
|
||||
});
|
||||
|
||||
function edit(obj) {
|
||||
layer.open({
|
||||
type: 2,
|
||||
// offset: 'r',
|
||||
// anim: 'slideLeft',
|
||||
title: '修改',
|
||||
shade: 0.1,
|
||||
area: ['99%', '98%'],
|
||||
content: "/income/edit?id=" + obj.data['id']
|
||||
});
|
||||
}
|
||||
|
||||
// 搜索条件
|
||||
function getQueryParams() {
|
||||
return {
|
||||
timeBegin: $('#timeBegin').val(),
|
||||
timeEnd: $('#timeEnd').val(),
|
||||
status: $('#status').val(),
|
||||
category: $('#category').val(),
|
||||
project: $('#project').val(),
|
||||
title: $('#title').val()
|
||||
};
|
||||
}
|
||||
|
||||
// 搜索
|
||||
function search_btn() {
|
||||
table.reload('tablelist', {
|
||||
where: getQueryParams(),
|
||||
page: {
|
||||
curr: 1
|
||||
}
|
||||
})
|
||||
return false;
|
||||
}
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
@@ -1,423 +0,0 @@
|
||||
{{template "header" .}}
|
||||
|
||||
<div class="layui-card" style="margin-bottom: 10px;">
|
||||
<div class="layui-card-body">
|
||||
<form class="layui-form layui-form-pane">
|
||||
{{.CsrfTokenField}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-item layui-inline">
|
||||
<div class="layui-input-inline">
|
||||
<select id="type" class="layui-input-sm">
|
||||
<option value="project">项目执行情况</option>
|
||||
<option value="budget">预算执行情况</option>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item layui-inline">
|
||||
<label class="layui-form-label">
|
||||
项目
|
||||
</label>
|
||||
<div class="layui-input-inline">
|
||||
<select id="project" class="layui-input-sm">
|
||||
{{range .Projects}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-inline">
|
||||
<button type="button" class="layui-btn layui-btn-sm" lay-submit lay-filter="user-query">
|
||||
<i class="layui-icon layui-icon-search"></i>
|
||||
查询
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-row layui-col-space10">
|
||||
<div class="layui-col-xs6 layui-col-md3">
|
||||
<div class="layui-card top-panel">
|
||||
<div class="layui-card-header">项目收入</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-row layui-col-space5">
|
||||
<div class="layui-col-xs8 layui-col-md8 top-panel-number" style="color: #1E84FF;font-size: 28px;"
|
||||
id="projectIncome"></div>
|
||||
<div class="layui-col-xs4 layui-col-md4 top-panel-tips">
|
||||
<svg xmlns="http://www.w3.org/2000/svg" class="icon" viewBox="0 0 1024 1024" width="50"
|
||||
height="50" t="1591462258798" p-id="942" version="1.1">
|
||||
<path fill="#fcc66f"
|
||||
d="M 262.7 835 c -15.3 0 -28.1 -11.4 -29.8 -26.6 L 174.1 291 c -0.6 -5.1 1 -10.2 4.5 -14 s 8.3 -6 13.4 -6 h 640 c 5.1 0 10 2.2 13.4 6 s 5 8.9 4.5 14 l -58.8 517.4 c -1.7 15.2 -14.5 26.6 -29.8 26.6 H 262.7 Z"
|
||||
p-id="943" />
|
||||
<path fill="#ffd79c"
|
||||
d="M 802 289 l -58.8 517.4 c -0.7 6.1 -5.8 10.6 -11.9 10.6 h 30 c 6.1 0 11.2 -4.6 11.9 -10.6 L 832 289 h -30 Z"
|
||||
p-id="944" />
|
||||
<path fill="#f56e73"
|
||||
d="M 164 307 c -16.5 0 -30 -13.5 -30 -30 v -58 c 0 -16.5 13.5 -30 30 -30 h 696 c 16.5 0 30 13.5 30 30 v 58 c 0 16.5 -13.5 30 -30 30 H 164 Z"
|
||||
p-id="945" />
|
||||
<path fill="#ffa1a8"
|
||||
d="M 860 207 h -30 c 6.6 0 12 5.4 12 12 v 58 c 0 6.6 -5.4 12 -12 12 h 30 c 6.6 0 12 -5.4 12 -12 v -58 c 0 -6.6 -5.4 -12 -12 -12 Z"
|
||||
p-id="946" />
|
||||
<path fill="#65c8ff"
|
||||
d="M 190.9 651.5 c -31.4 0 -56.9 -25.5 -56.9 -56.9 V 219 c 0 -16.5 13.5 -30 30 -30 h 466.2 c 9.9 0 18 8.1 18 18 v 301.1 c 0 34.7 -28.2 62.9 -62.9 62.9 s -62.9 -28.2 -62.9 -62.9 V 393.5 c 0 -23.2 -18.8 -42 -42 -42 s -42 18.8 -42 42 v 68.1 c 0 29.4 -23.9 53.4 -53.4 53.4 s -53.4 -23.9 -53.4 -53.4 v -68.1 c 0 -23.2 -18.8 -42 -42 -42 s -42 18.8 -42 42 v 201.1 c 0.1 31.4 -25.4 56.9 -56.7 56.9 Z"
|
||||
p-id="947" />
|
||||
<path fill="#b3eaff"
|
||||
d="M 277.8 321.5 c -33.1 0 -60 26.9 -60 60 v 201.1 c 0 21.5 -17.4 38.9 -38.9 38.9 c -7.7 0 -14.8 -2.2 -20.8 -6.1 c 6.9 10.9 19 18.1 32.8 18.1 c 21.5 0 38.9 -17.4 38.9 -38.9 V 393.5 c 0 -33.1 26.9 -60 60 -60 c 13.5 0 25.9 4.5 36 12 c -11 -14.5 -28.4 -24 -48 -24 Z M 618.3 207 v 289.1 c 0 24.8 -20.1 44.9 -44.9 44.9 c -9.3 0 -18 -2.8 -25.2 -7.7 c 8.1 11.9 21.7 19.7 37.2 19.7 c 24.8 0 44.9 -20.1 44.9 -44.9 V 207 h -12 Z M 468.5 321.5 c -33.1 0 -60 26.9 -60 60 v 68.1 c 0 19.5 -15.8 35.4 -35.4 35.4 c -6.7 0 -12.9 -1.9 -18.3 -5.1 c 6.2 10.2 17.4 17.1 30.3 17.1 c 19.5 0 35.4 -15.8 35.4 -35.4 v -68.1 c 0 -33.1 26.9 -60 60 -60 c 13.5 0 25.9 4.5 36 12 c -11 -14.5 -28.4 -24 -48 -24 Z"
|
||||
p-id="948" />
|
||||
<path fill="#453b56" d="M 698 729.4 m -18 0 a 18 18 0 1 0 36 0 a 18 18 0 1 0 -36 0 Z"
|
||||
p-id="949" />
|
||||
<path fill="#453b56"
|
||||
d="M 860 171 H 632.5 v 0.1 c -0.7 0 -1.5 -0.1 -2.2 -0.1 H 164 c -26.5 0 -48 21.5 -48 48 v 375.6 c 0 41.3 33.6 74.9 74.9 74.9 c 2.7 0 5.4 -0.2 8.1 -0.5 l 16 141.4 c 2.8 24.3 23.3 42.6 47.7 42.6 h 498.6 c 24.4 0 44.9 -18.3 47.7 -42.6 l 55.2 -485.6 c 24.5 -2.1 43.8 -22.7 43.8 -47.8 v -58 c 0 -26.5 -21.5 -48 -48 -48 Z M 190.9 633.5 c -21.5 0 -38.9 -17.4 -38.9 -38.9 V 219 c 0 -6.6 5.4 -12 12 -12 h 466.3 v 301.1 c 0 24.8 -20.1 44.9 -44.9 44.9 c -24.8 0 -44.9 -20.1 -44.9 -44.9 V 393.5 c 0 -33.1 -26.9 -60 -60 -60 s -60 26.9 -60 60 v 68.1 c 0 19.5 -15.8 35.4 -35.4 35.4 c -19.5 0 -35.4 -15.8 -35.4 -35.4 v -68.1 c 0 -33.1 -26.9 -60 -60 -60 s -60 26.9 -60 60 v 201.1 c 0.1 21.5 -17.4 38.9 -38.8 38.9 Z m 582.3 172.9 c -0.7 6.1 -5.8 10.6 -11.9 10.6 H 262.7 c -6.1 0 -11.2 -4.6 -11.9 -10.6 l -6.7 -59 h 396.6 c 9.9 0 18 -8.1 18 -18 s -8.1 -18 -18 -18 H 240 l -6.3 -55.4 c 19.3 -13.6 32.1 -36 32.1 -61.3 V 393.5 c 0 -13.2 10.8 -24 24 -24 s 24 10.8 24 24 v 68.1 c 0 39.4 32 71.4 71.4 71.4 s 71.4 -32 71.4 -71.4 v -68.1 c 0 -13.2 10.8 -24 24 -24 s 24 10.8 24 24 v 114.6 c 0 44.6 36.3 80.9 80.9 80.9 c 44.6 0 80.9 -36.3 80.9 -80.9 V 325 h 161.7 l -54.9 481.4 Z M 872 277 c 0 6.6 -5.4 12 -12 12 H 666.3 v -82 H 860 c 6.6 0 12 5.4 12 12 v 58 Z"
|
||||
p-id="950" />
|
||||
</svg>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs6 layui-col-md3">
|
||||
<div class="layui-card top-panel">
|
||||
<div class="layui-card-header">项目支出</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-row layui-col-space5">
|
||||
<div class="layui-col-xs8 layui-col-md8 top-panel-number" style="color: #1E84FF;font-size: 28px;"
|
||||
id="projectExpense"></div>
|
||||
<div class="layui-col-xs4 layui-col-md4 top-panel-tips">
|
||||
<svg t="1591462430908" class="icon" viewBox="0 0 1024 1024" version="1.1"
|
||||
xmlns="http://www.w3.org/2000/svg" p-id="3170" width="50" height="50">
|
||||
<path
|
||||
d="M532 784.2c0 24.4-19.8 44.3-44.3 44.3s-44.3-19.8-44.3-44.3c0-24.4 44.3-80.3 44.3-80.3s44.3 55.8 44.3 80.3zM766 784.2c0 24.4 19.8 44.3 44.3 44.3 24.4 0 44.3-19.8 44.3-44.3 0-24.4-44.3-80.3-44.3-80.3S766 759.7 766 784.2z"
|
||||
fill="#97DCFF" p-id="3171"></path>
|
||||
<path
|
||||
d="M123.5 471.3c-9.9 0-18-8.1-18-18v-302c0-9.9 8.1-18 18-18h58c9.9 0 18 8.1 18 18v302c0 9.9-8.1 18-18 18h-58z"
|
||||
fill="#FCC66F" p-id="3172"></path>
|
||||
<path
|
||||
d="M181.5 151.3v302h-58v-302h58m0-36h-58c-19.9 0-36 16.1-36 36v302c0 19.9 16.1 36 36 36h58c19.9 0 36-16.1 36-36v-302c0-19.8-16.1-36-36-36z"
|
||||
fill="#453B56" p-id="3173"></path>
|
||||
<path d="M266.4 210.7m-18 0a18 18 0 1 0 36 0 18 18 0 1 0-36 0Z" fill="#453B56" p-id="3174">
|
||||
</path>
|
||||
<path
|
||||
d="M430.8 641.1c-9.9 0-18-8.1-18-18v-21.6c0-130.3 106-236.3 236.3-236.3s236.3 106 236.3 236.3v21.6c0 9.9-8.1 18-18 18H430.8z"
|
||||
fill="#FCC66F" p-id="3175"></path>
|
||||
<path
|
||||
d="M649 383.2c-5 0-10 0.2-15 0.6 113.5 7.7 203.3 102.2 203.3 217.7v21.6h30v-21.6c0-120.6-97.7-218.3-218.3-218.3z"
|
||||
fill="#FFD79C" p-id="3176"></path>
|
||||
<path
|
||||
d="M419.6 694.4c-22.1 0-40.1-18-40.1-40.1s18-40.1 40.1-40.1h458.8c22.1 0 40.1 18 40.1 40.1s-18 40.1-40.1 40.1H419.6z"
|
||||
fill="#F56E73" p-id="3177"></path>
|
||||
<path
|
||||
d="M878.4 632.3h-30c12.2 0 22.1 9.9 22.1 22.1s-9.9 22.1-22.1 22.1h30c12.2 0 22.1-9.9 22.1-22.1s-9.9-22.1-22.1-22.1z"
|
||||
fill="#FFA1A8" p-id="3178"></path>
|
||||
<path
|
||||
d="M693.3 846.4c0 24.4-19.8 44.3-44.3 44.3-24.4 0-44.3-19.8-44.3-44.3s44.3-80.3 44.3-80.3 44.3 55.9 44.3 80.3z"
|
||||
fill="#97DCFF" p-id="3179"></path>
|
||||
<path
|
||||
d="M649 908.7c-34.3 0-62.3-27.9-62.3-62.3 0-28.5 36.9-77.2 48.1-91.4 3.4-4.3 8.6-6.8 14.1-6.8s10.7 2.5 14.1 6.8c11.3 14.2 48.1 62.9 48.1 91.4 0.2 34.3-27.8 62.3-62.1 62.3z m0-112.3c-14.1 20.4-26.3 41.9-26.3 50 0 14.5 11.8 26.3 26.3 26.3s26.3-11.8 26.3-26.3c0-8.1-12.1-29.6-26.3-50z"
|
||||
fill="#453B56" p-id="3180"></path>
|
||||
<path
|
||||
d="M903.3 601.9v-0.5c0-134.1-104.4-244.3-236.3-253.6v-30.7c0-68.7-55.9-124.6-124.6-124.6H326.5c-9.9 0-18 8.1-18 18s8.1 18 18 18h215.9c48.8 0 88.6 39.7 88.6 88.6v30.7c-131.8 9.3-236.3 119.4-236.3 253.6v0.5c-19.6 9.3-33.2 29.3-33.2 52.4 0 32 26 58.1 58.1 58.1H459c-14.8 21-33.5 51.5-33.5 71.8 0 34.3 27.9 62.3 62.3 62.3 34.3 0 62.2-27.9 62.2-62.3 0-20.3-18.6-50.7-33.5-71.8h264.9c-14.8 21-33.5 51.5-33.5 71.8 0 34.3 27.9 62.3 62.3 62.3 34.3 0 62.3-27.9 62.3-62.3 0-20.3-18.6-50.7-33.5-71.8h39.4c32 0 58.1-26 58.1-58.1 0-23.1-13.6-43-33.2-52.4zM487.8 810.4c-14.5 0-26.3-11.8-26.3-26.3 0-8.1 12.1-29.6 26.3-50 14.1 20.4 26.2 41.9 26.2 50 0 14.5-11.8 26.3-26.2 26.3z m322.5 0c-14.5 0-26.3-11.8-26.3-26.3 0-8.1 12.1-29.6 26.3-50 14.1 20.4 26.3 41.9 26.3 50-0.1 14.5-11.9 26.3-26.3 26.3zM649 383.2c118.8 0 215.4 94.9 218.1 213.1H430.9c2.8-118.1 99.3-213.1 218.1-213.1z m251.5 271.1c0 12.2-9.9 22.1-22.1 22.1H419.6c-12.2 0-22.1-9.9-22.1-22.1 0-12.2 9.9-22.1 22.1-22.1h458.8c12.2 0.1 22.1 10 22.1 22.1z"
|
||||
fill="#453B56" p-id="3181"></path>
|
||||
</svg>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs6 layui-col-md3">
|
||||
<div class="layui-card top-panel">
|
||||
<div class="layui-card-header">项目利润</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-row layui-col-space5">
|
||||
<div class="layui-col-xs8 layui-col-md8 top-panel-number" style="color: #1E84FF;font-size: 28px;"
|
||||
id="projectProfit"></div>
|
||||
<div class="layui-col-xs4 layui-col-md4 top-panel-tips">
|
||||
<svg t="1591462464512" class="icon" viewBox="0 0 1024 1024" version="1.1"
|
||||
xmlns="http://www.w3.org/2000/svg" p-id="3311" width="50" height="50">
|
||||
<path
|
||||
d="M750.4 216.5h-130v-15.3c0-32.9-26.8-59.7-59.7-59.7h-97.3c-32.9 0-59.7 26.8-59.7 59.7v15.3h-130c-30.7 0-55.6 25-55.6 55.6v72.4c0 9.9 8.1 18 18 18h31.5v478c0 23.2 18.8 42 42 42h405c23.2 0 42-18.8 42-42v-478H788c9.9 0 18-8.1 18-18v-72.4c0-30.6-25-55.6-55.6-55.6z"
|
||||
fill="#FCC66F" p-id="3312"></path>
|
||||
<path d="M708.5 344.5v496c0 13.3-10.7 24-24 24h30c13.3 0 24-10.7 24-24v-496h-30z"
|
||||
fill="#FFD79C" p-id="3313"></path>
|
||||
<path
|
||||
d="M309.5 882.5c-23.2 0-42-18.8-42-42V596c0-9.9 8.1-18 18-18h36.8c30.2 0 54.8 24.6 54.8 54.8v231.7c0 9.9-8.1 18-18 18h-49.6zM664.9 882.5c-9.9 0-18-8.1-18-18V632.8c0-30.2 24.6-54.8 54.8-54.8h36.8c9.9 0 18 8.1 18 18v244.5c0 23.2-18.8 42-42 42h-49.6z"
|
||||
fill="#F56E73" p-id="3314"></path>
|
||||
<path d="M708.5 596v244.5c0 13.3-10.7 24-24 24h30c13.3 0 24-10.7 24-24V596h-30z"
|
||||
fill="#FFA1A8" p-id="3315"></path>
|
||||
<path
|
||||
d="M475.2 882.5c-9.9 0-18-8.1-18-18V632.8c0-30.2 24.6-54.8 54.8-54.8 30.2 0 54.8 24.6 54.8 54.8v231.7c0 9.9-8.1 18-18 18h-73.6z"
|
||||
fill="#F56E73" p-id="3316"></path>
|
||||
<path
|
||||
d="M560.7 159.5h-18c23 0 41.7 18.7 41.7 41.7V221h18v-19.8c-0.1-23-18.7-41.7-41.7-41.7zM750.4 234.5h-30c20.8 0 37.6 16.8 37.6 37.6v72.4h30v-72.4c0-20.8-16.8-37.6-37.6-37.6z"
|
||||
fill="#FFD79C" p-id="3317"></path>
|
||||
<path
|
||||
d="M750.4 198.5H638.2c-1.4-41.6-35.6-75-77.5-75h-97.3c-41.9 0-76.1 33.4-77.5 75H273.6c-40.6 0-73.6 33-73.6 73.6v72.4c0 19.9 16.1 36 36 36h13.5v460c0 33.1 26.9 60 60 60H714.7c33.1 0 60-26.9 60-60v-460H788c19.9 0 36-16.1 36-36v-72.4c0-40.6-33-73.6-73.6-73.6z m-287.1-39h97.3c22.1 0 40.2 17.2 41.5 39H421.8c1.4-21.8 19.4-39 41.5-39z m-104.2 705h-49.6c-13.3 0-24-10.7-24-24V596h36.8c20.3 0 36.8 16.5 36.8 36.8v231.7z m189.7 0h-73.6V632.8c0-20.3 16.5-36.8 36.8-36.8 20.3 0 36.8 16.5 36.8 36.8v231.7z m189.7-24c0 13.3-10.7 24-24 24h-49.6V632.8c0-20.3 16.5-36.8 36.8-36.8h36.8v244.5z m0-280.5h-36.8c-40.1 0-72.8 32.6-72.8 72.8v231.7h-44.2V632.8c0-40.1-32.6-72.8-72.8-72.8-40.1 0-72.8 32.6-72.8 72.8v231.7h-44.2V632.8c0-40.1-32.6-72.8-72.8-72.8h-36.8v-74.5h279c9.9 0 18-8.1 18-18s-8.1-18-18-18h-279v-69h453V560zM788 344.5H236v-72.4c0-20.8 16.8-37.6 37.6-37.6h476.8c20.8 0 37.6 16.8 37.6 37.6v72.4z"
|
||||
fill="#453B56" p-id="3318"></path>
|
||||
<path d="M621.8 467.5m-18 0a18 18 0 1 0 36 0 18 18 0 1 0-36 0Z" fill="#453B56" p-id="3319">
|
||||
</path>
|
||||
</svg>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs6 layui-col-md3">
|
||||
<div class="layui-card top-panel">
|
||||
<div class="layui-card-header">项目利润率</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-row layui-col-space5">
|
||||
<div class="layui-col-xs8 layui-col-md8 top-panel-number" style="color: #1E84FF;font-size: 28px;"
|
||||
id="projectProfitRate"></div>
|
||||
<div class="layui-col-xs4 layui-col-md4 top-panel-tips">
|
||||
<svg t="1591462491887" class="icon" viewBox="0 0 1024 1024" version="1.1"
|
||||
xmlns="http://www.w3.org/2000/svg" p-id="3449" width="50" height="50">
|
||||
<path
|
||||
d="M363.2 807c-9.9 0-18-8.1-18-18v-75.5c0-9.9 8.1-18 18-18h108.5c9.9 0 18 8.1 18 18V789c0 9.9-8.1 18-18 18H363.2z"
|
||||
fill="#F56E73" p-id="3450"></path>
|
||||
<path d="M441.7 713.5h30V789h-30z" fill="#FFA1A8" p-id="3451"></path>
|
||||
<path
|
||||
d="M259.6 398c-9.9 0-18-8.1-18-18V178.6c0-23.8 19.3-43.1 43.1-43.1s43.1 19.3 43.1 43.1V380c0 9.9-8.1 18-18 18h-50.2zM525.1 398c-9.9 0-18-8.1-18-18V178.6c0-23.8 19.3-43.1 43.1-43.1s43.1 19.3 43.1 43.1V380c0 9.9-8.1 18-18 18h-50.2z"
|
||||
fill="#65C8FF" p-id="3452"></path>
|
||||
<path
|
||||
d="M550.2 153.5c-3.2 0-6.2 0.7-9 1.7 9.4 3.6 16.1 12.7 16.1 23.4V380h18V178.6c0.1-13.9-11.2-25.1-25.1-25.1z"
|
||||
fill="#97DCFF" p-id="3453"></path>
|
||||
<path
|
||||
d="M686 330.5H149c-9.9 0-18 8.1-18 18v63c0 9.9 8.1 18 18 18h33.2l45 225c8.7 43.4 47.1 75 91.4 75h197.6c44.3 0 82.7-31.5 91.4-75l45-225H686c9.9 0 18-8.1 18-18v-63c0-9.9-8.1-18-18-18z"
|
||||
fill="#FCC66F" p-id="3454"></path>
|
||||
<path
|
||||
d="M608 411.5L560.1 651c-7 35.2-37.9 60.5-73.8 60.5h30c35.9 0 66.7-25.3 73.8-60.5L638 411.5h-30zM656 348.5h30v63h-30z"
|
||||
fill="#FFD79C" p-id="3455"></path>
|
||||
<path d="M474.2 543.5m-18 0a18 18 0 1 0 36 0 18 18 0 1 0-36 0Z" fill="#453B56" p-id="3456">
|
||||
</path>
|
||||
<path
|
||||
d="M416.9 525.5h-125c-9.9 0-18 8.1-18 18s8.1 18 18 18h125c9.9 0 18-8.1 18-18s-8.1-18-18-18zM893 543.5h-33.4c-65.2 0-118.2 53-118.2 118.2v19.6c0 9.9 8.1 18 18 18s18-8.1 18-18v-19.6c0-45.3 36.9-82.2 82.2-82.2H893c9.9 0 18-8.1 18-18s-8-18-18-18zM772.2 744.2c7-7 7-18.4 0-25.5-7-7-18.4-7-25.5 0s-7 18.4 0 25.5 18.4 7.1 25.5 0z"
|
||||
fill="#453B56" p-id="3457"></path>
|
||||
<path
|
||||
d="M759.5 761.6c-9.9 0-18 8.1-18 18v11.6c0 43.7-35.6 79.3-79.3 79.3H487.3c-26.4 0-48.3-19.9-51.4-45.5h35.8c19.9 0 36-16.1 36-36v-41.5h8.6c52.8 0 98.7-37.6 109.1-89.4l42.1-210.6H686c19.9 0 36-16.1 36-36v-63c0-19.9-16.1-36-36-36h-74.6V178.6c0-33.7-27.4-61.1-61.1-61.1s-61.1 27.4-61.1 61.1v133.9H345.9V178.6c0-33.7-27.4-61.1-61.1-61.1s-61.1 27.4-61.1 61.1v133.9H149c-19.9 0-36 16.1-36 36v63c0 19.9 16.1 36 36 36h18.5l42.1 210.6c10.4 51.8 56.2 89.4 109.1 89.4h8.6V789c0 19.9 16.1 36 36 36h36.6c3.3 45.5 41.2 81.5 87.5 81.5h174.8c63.6 0 115.3-51.7 115.3-115.3v-11.6c0-10-8.1-18-18-18z m-234.4-583c0-13.9 11.2-25.1 25.1-25.1s25.1 11.2 25.1 25.1v133.9H525V178.6z m-265.5 0c0-13.9 11.2-25.1 25.1-25.1s25.1 11.2 25.1 25.1v133.9h-50.3V178.6zM149 411.5v-63h537v63H149z m169.7 300c-35.9 0-66.7-25.3-73.8-60.5l-40.7-203.5h426.6L590.1 651c-7 35.2-37.9 60.5-73.8 60.5H318.7z m44.5 77.5v-41.5h108.5V789H363.2z"
|
||||
fill="#453B56" p-id="3458"></path>
|
||||
</svg>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-row layui-col-space10">
|
||||
<div class="layui-col-md4">
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-body">
|
||||
<div id="project_income_expense" style="min-height:400px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-md4">
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-body">
|
||||
<div id="project_income" style="min-height:400px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-md4">
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-body">
|
||||
<div id="project_expense" style="min-height:400px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-row layui-col-space10">
|
||||
<div class="layui-col-md12">
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">收入列表</div>
|
||||
<div class="layui-card-body">
|
||||
<table id="income_list" lay-filter="income_list"></table>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-row layui-col-space10">
|
||||
<div class="layui-col-md12">
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">支出列表</div>
|
||||
<div class="layui-card-body">
|
||||
<table id="expense_list" lay-filter="expense_list"></table>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['table', 'form', 'jquery', 'laydate', 'xmSelect', 'util', 'echarts'], function () {
|
||||
let $ = layui.jquery;
|
||||
let table = layui.table;
|
||||
let form = layui.form;
|
||||
let xmSelect = layui.xmSelect;
|
||||
let util = layui.util;
|
||||
let laydate = layui.laydate;
|
||||
let echarts = layui.echarts;
|
||||
|
||||
var pie = echarts.init(document.getElementById('project_income_expense'));
|
||||
var pi = echarts.init(document.getElementById('project_income'));
|
||||
var pe = echarts.init(document.getElementById('project_expense'));
|
||||
|
||||
search();
|
||||
getProject();
|
||||
projectInfo(getProject());
|
||||
loadIncomeList();
|
||||
loadExpenseList();
|
||||
|
||||
// 搜索
|
||||
function search() {
|
||||
form.on('submit(user-query)', function (data) {
|
||||
// table.reload('tablelist', {
|
||||
// where: getQueryParams(),
|
||||
// page: {
|
||||
// curr: 1
|
||||
// }
|
||||
// })
|
||||
var type = $('#type').val();
|
||||
if (type == 'project') {
|
||||
projectInfo(getProject());
|
||||
loadIncomeList();
|
||||
loadExpenseList();
|
||||
} else if (type == 'budget') {
|
||||
|
||||
}
|
||||
return false;
|
||||
});
|
||||
}
|
||||
|
||||
function projectInfo(projectId) {
|
||||
$.ajax({
|
||||
url: '/project/dashboard',
|
||||
type: 'POST',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
data: {
|
||||
'type': 'project',
|
||||
'projectID': projectId
|
||||
},
|
||||
success: function (res) {
|
||||
if (res.success) {
|
||||
let data = res.data;
|
||||
$('#projectIncome').text(data.project_income);
|
||||
$('#projectExpense').text(data.project_expense);
|
||||
$('#projectProfit').text(data.project_profit);
|
||||
$('#projectProfitRate').text(data.project_profit_rate);
|
||||
|
||||
pie.setOption(data.income_expense_echarts);
|
||||
pi.setOption(data.income_echarts);
|
||||
pe.setOption(data.expense_echarts);
|
||||
}
|
||||
},
|
||||
error: function (err) {
|
||||
console.log(err);
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
window.onresize = function () {
|
||||
pie.resize();
|
||||
pi.resize();
|
||||
pe.resize();
|
||||
}
|
||||
|
||||
function getProject() {
|
||||
return $('#project').val();
|
||||
// $.ajax({
|
||||
// url: '/project/xmselect',
|
||||
// type: 'post',
|
||||
// dataType: 'json',
|
||||
// headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
// success: function (res) {
|
||||
// xmSelect.render({
|
||||
// el: '#ProjectID',
|
||||
// // 工具栏
|
||||
// radio: true,
|
||||
// toolbar: {
|
||||
// show: true
|
||||
// },
|
||||
// tips: '请选择项目',
|
||||
// filterable: true,
|
||||
// data: res,
|
||||
// name: 'ProjectID',
|
||||
// on: function (data) {
|
||||
// // console.log(data);
|
||||
// // console.log(data.arr[0].value);
|
||||
// projectId = data.arr[0].value;
|
||||
// },
|
||||
// });
|
||||
// },
|
||||
// error: function (err) {
|
||||
// // 处理请求错误
|
||||
// console.log('请求出错:', err);
|
||||
// }
|
||||
// });
|
||||
}
|
||||
|
||||
// 加载列表
|
||||
function loadIncomeList() {
|
||||
table.render({
|
||||
elem: '#income_list',
|
||||
url: "/income/list",
|
||||
method: "POST",
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
where: getIncomeQueryParams(),
|
||||
height: 'full',
|
||||
page: true,
|
||||
cols: [[
|
||||
{ field: 'id', title: '回款编号', align: 'left', fixed: 'left', width: 100 },
|
||||
{ field: 'project_name', title: '关联项目', align: 'left', width: 200 },
|
||||
{ field: 'budget_name', title: '关联预算', align: 'left', width: 200 },
|
||||
{ field: 'income_type_name', title: '回款类别', align: 'left', width: 100 },
|
||||
{ field: 'income_at', title: '回款时间', align: 'left', width: 160, templet: function (d) { return !d.income_at ? '' : util.toDateString(d.income_at) } },
|
||||
{ field: 'amount', title: '回款金额', align: 'left', width: 120 },
|
||||
]],
|
||||
skin: 'line',
|
||||
defaultToolbar: [],
|
||||
});
|
||||
}
|
||||
|
||||
function getIncomeQueryParams() {
|
||||
return {
|
||||
project: $('#project').val(),
|
||||
};
|
||||
}
|
||||
|
||||
function loadExpenseList() {
|
||||
table.render({
|
||||
elem: '#expense_list',
|
||||
url: "/expense/list",
|
||||
method: "POST",
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
where: getExpenseQueryParams(),
|
||||
height: 'full',
|
||||
page: true,
|
||||
cols: [[
|
||||
{ field: 'id', title: '报销编号', align: 'left', fixed: 'left', width: 100 },
|
||||
{ field: 'project_name', title: '关联项目', align: 'left', width: 200 },
|
||||
{ field: 'budget_name', title: '关联预算', align: 'left', width: 200 },
|
||||
{ field: 'expenses_type_name', title: '报销类别', align: 'left', width: 100 },
|
||||
{ field: 'expenses_at', title: '报销时间', align: 'left', width: 160, templet: function (d) { return !d.expenses_at ? '' : util.toDateString(d.expenses_at) } },
|
||||
{ field: 'amount', title: '报销金额', align: 'left', width: 120 },
|
||||
]],
|
||||
skin: 'line',
|
||||
defaultToolbar: []
|
||||
});
|
||||
}
|
||||
|
||||
function getExpenseQueryParams() {
|
||||
return {
|
||||
project: $('#project').val()
|
||||
};
|
||||
}
|
||||
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
@@ -1,516 +0,0 @@
|
||||
{{template "header"}}
|
||||
|
||||
<div class="edit-box">
|
||||
<form class="layui-form">
|
||||
{{.CsrfTokenField}}
|
||||
<input type="hidden" id="ID" name="ID" value="{{.Item.ID}}" />
|
||||
|
||||
<div class="layui-tab-content" style="padding-top: 0;">
|
||||
<div class="layui-tab-item layui-show">
|
||||
<!-- <div class="layui-card">
|
||||
<div class="layui-card-header">客户信息</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">选择客户</div>
|
||||
<div class="layui-input-inline" id="CustomerID" style="width: 240px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div> -->
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header layui-card-header-slipt">客户信息</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">选择客户</div>
|
||||
<div class="layui-input-inline">
|
||||
<button type="button" id="selectCustomer"
|
||||
class="layui-btn layui-btn-primary layui-border">
|
||||
<i class="layui-icon layui-icon-search"></i>
|
||||
选择数据
|
||||
</button>
|
||||
</div>
|
||||
<div class="layui-form-label">客户编号</div>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="CustomerID" name="CustomerID" value="{{.Item.CustomerID}}"
|
||||
lay-verify="required" readonly autocomplete="off" placeholder="请输入客户编号"
|
||||
class="layui-input" />
|
||||
</div>
|
||||
<div class="layui-form-label">客户名称</div>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="CustomerName" name="CustomerName" value="{{.Item.CustomerName}}"
|
||||
readonly autocomplete="off" placeholder="请输入客户名称" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">项目信息</div>
|
||||
<div class="layui-card-body">
|
||||
{{if .Item.ID}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">编号</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.ID}}
|
||||
</div>
|
||||
</div>
|
||||
{{end}}
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">名称</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="Name" name="Name" value="{{.Item.Name}}" lay-verify="required"
|
||||
autocomplete="off" placeholder="请输入名称" class="layui-input" style="width:700px;" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">状态</label>
|
||||
<div class="layui-input-inline" style="width:600px;">
|
||||
{{range .Statuses}}
|
||||
{{if.Selected}}
|
||||
<input type="radio" name="Status" value="{{.Value}}" title="{{.Name}}" checked>
|
||||
{{else}}
|
||||
<input type="radio" name="Status" value="{{.Value}}" title="{{.Name}}">
|
||||
{{end}}
|
||||
{{end}}
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">开始时间</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="StartAt" name="StartAt" value="{{.Item.StartAt}}"
|
||||
lay-verify="required" autocomplete="off" placeholder="请输入名称" class="layui-input" />
|
||||
</div>
|
||||
<label class="layui-form-label">结束时间</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="EndAt" name="EndAt" value="{{.Item.EndAt}}" lay-verify="required"
|
||||
autocomplete="off" placeholder="请输入名称" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">总金额</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="TotalMoney" name="TotalMoney" value="{{.Item.TotalMoney}}"
|
||||
lay-verify="required" autocomplete="off" placeholder="请输入总金额" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">简介</label>
|
||||
<div class="layui-input-inline">
|
||||
<textarea id="Description" name="Description" class="layui-textarea"
|
||||
style="width: 600px; height: 60px;">{{.Item.Description}}</textarea>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">物料</label>
|
||||
<div class="layui-input-inline" style="width: auto;">
|
||||
{{template "upload_mutil" .Item.ProjectFiles}}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">项目团队</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">项目经理</div>
|
||||
<div class="layui-input-inline" id="ManagerID" style="width: 400px;"></div>
|
||||
<div class="layui-form-label">项目成员</div>
|
||||
<div class="layui-input-inline" id="Members" style="width: 400px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">申请信息</div>
|
||||
<div class="layui-card-body">
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">申请人</div>
|
||||
<div class="layui-input-inline" id="ApplyUserID" style="width: 400px;"></div>
|
||||
<label class="layui-form-label">申请时间</label>
|
||||
<div class="layui-input-inline">
|
||||
<input type="text" id="ApplyAt" name="ApplyAt" value="{{.Item.ApplyAt}}"
|
||||
lay-verify="required" autocomplete="off" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-header">其他</div>
|
||||
<div class="layui-card-body">
|
||||
{{if .Item.ID}}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">创建</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.CreatedName}}
|
||||
({{dateFormat .Item.CreatedAt}})
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-form-label">更新</div>
|
||||
<div class="layui-form-label" style="width:400px;text-align:left;">
|
||||
{{.Item.UpdatedName}}
|
||||
({{dateFormat .Item.UpdatedAt}})
|
||||
</div>
|
||||
</div>
|
||||
{{end}}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item layui-fixbar btn-fixbar-box">
|
||||
<div class="layui-input-block">
|
||||
{{ submitBtn .AuthorizeMenus "save"}}
|
||||
<button type="button" class="layui-btn layui-btn-primary layui-btn-sm" lay-on="close">
|
||||
<i class="layui-icon layui-icon-close"></i>关闭
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</form>
|
||||
</div>
|
||||
|
||||
{{define "css"}}
|
||||
<style>
|
||||
.layui-body {
|
||||
padding: 15px;
|
||||
left: 0;
|
||||
}
|
||||
|
||||
.loader::after {
|
||||
content: '';
|
||||
}
|
||||
</style>
|
||||
{{end}}
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['table', 'form', 'jquery', 'iconPicker', 'laydate', 'dtree', 'xmSelect', "util"], function () {
|
||||
let $ = layui.jquery;
|
||||
let table = layui.table;
|
||||
let form = layui.form;
|
||||
let iconPicker = layui.iconPicker;
|
||||
let dtree = layui.dtree;
|
||||
let xmSelect = layui.xmSelect;
|
||||
let util = layui.util;
|
||||
let laydate = layui.laydate;
|
||||
|
||||
/**开始时间 */
|
||||
laydate.render({
|
||||
elem: '#StartAt',
|
||||
type: 'date',
|
||||
value: '{{today}}',
|
||||
});
|
||||
|
||||
/**截止时间 */
|
||||
laydate.render({
|
||||
elem: '#EndAt',
|
||||
type: 'date',
|
||||
value: '{{threeMonth}}',
|
||||
});
|
||||
|
||||
laydate.render({
|
||||
elem: '#ApplyAt',
|
||||
type: 'date',
|
||||
value: '{{today}}',
|
||||
});
|
||||
|
||||
// 表单提交
|
||||
form.on('submit(save)', function (data) {
|
||||
$.ajax({
|
||||
url: '/project/save',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
data: data.field,
|
||||
success: function (result) {
|
||||
if (result.success) {
|
||||
layer.msg(result.msg, { icon: 1, time: 1000 }, function () {
|
||||
parent.layer.close(parent.layer.getFrameIndex(window.name)); // 关闭当前页
|
||||
parent.layui.table.reload("tablelist", {
|
||||
page: { curr: 1 },
|
||||
});
|
||||
});
|
||||
} else {
|
||||
parent.layer.msg(result.msg, { icon: 2 })
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
return false;
|
||||
});
|
||||
|
||||
// 事件绑定
|
||||
util.on("lay-on", {
|
||||
"close": function () {
|
||||
window.parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
}
|
||||
});
|
||||
|
||||
//getCustomer();
|
||||
getUser();
|
||||
|
||||
// function getCustomer() {
|
||||
// $.ajax({
|
||||
// url: '/customer/xmselect',
|
||||
// type: 'post',
|
||||
// dataType: 'json',
|
||||
// headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
// success: function (res) {
|
||||
// xmSelect.render({
|
||||
// el: '#CustomerID',
|
||||
// // 工具栏
|
||||
// radio: true,
|
||||
// toolbar: {
|
||||
// show: true
|
||||
// },
|
||||
// tips: '请选择客户',
|
||||
// filterable: true,
|
||||
// data: res,
|
||||
// name: 'CustomerID',
|
||||
// initValue: ['{{.Item.CustomerID}}'],
|
||||
// on: function (data) { },
|
||||
// });
|
||||
// },
|
||||
// error: function (err) {
|
||||
// // 处理请求错误
|
||||
// console.log('请求出错:', err);
|
||||
// }
|
||||
// });
|
||||
// }
|
||||
|
||||
function getUser() {
|
||||
let array = '{{.Item.Members}}';
|
||||
$.ajax({
|
||||
url: '/system/user/data?type=xmselect',
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
success: function (res) {
|
||||
xmSelect.render({
|
||||
el: '#ApplyUserID',
|
||||
// 工具栏
|
||||
radio: true,
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择申请人',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'ApplyUserID',
|
||||
initValue: ['{{.Item.ApplyUserID}}'],
|
||||
on: function (data) { },
|
||||
});
|
||||
|
||||
xmSelect.render({
|
||||
el: '#ManagerID',
|
||||
// 工具栏
|
||||
radio: true,
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择项目经理',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'ManagerID',
|
||||
initValue: ['{{.Item.ManagerID}}'],
|
||||
on: function (data) { },
|
||||
});
|
||||
|
||||
|
||||
xmSelect.render({
|
||||
el: '#Members',
|
||||
// 工具栏
|
||||
toolbar: {
|
||||
show: true
|
||||
},
|
||||
tips: '请选择项目成员',
|
||||
filterable: true,
|
||||
data: res,
|
||||
name: 'Members',
|
||||
initValue: array.split(','),
|
||||
on: function (data) { },
|
||||
});
|
||||
},
|
||||
error: function (err) {
|
||||
// 处理请求错误
|
||||
console.log('请求出错:', err);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
let customerLayer;
|
||||
$('#selectCustomer').on('click', function () {
|
||||
customerLayer = layer.open({
|
||||
type: 1, // page 层类型
|
||||
area: ['70%', '90%'],
|
||||
title: '选择数据',
|
||||
scrollbar: false,
|
||||
shade: 0.2, // 遮罩透明度
|
||||
shadeClose: false, // 点击遮罩区域,关闭弹层
|
||||
maxmin: false, // 允许全屏最小化
|
||||
anim: 0, // 0-6 的动画形式,-1 不开启
|
||||
content: '<table id="customer_list" lay-filter="customer_list"></table>',
|
||||
success: function (layero, index, that) {
|
||||
// layero 弹层的最外层元素的 jQuery 对象
|
||||
// index 弹层的索引值
|
||||
// that 弹层内部原型链中的 this --- 2.8+
|
||||
loadCustomerList();
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
function loadCustomerList() {
|
||||
table.render({
|
||||
elem: '#customer_list',
|
||||
url: "/customer/list",
|
||||
method: "POST",
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
//height: 'full',
|
||||
height: function () {
|
||||
return $(window).height() - 135;
|
||||
},
|
||||
page: true,
|
||||
cols: [[
|
||||
{ field: 'name', title: '名称', align: 'left', fixed: 'left', width: 200 },
|
||||
{ field: 'sid', title: '编号', align: 'left', width: 180 },
|
||||
{ field: 'category_name', title: '类别', align: 'left', width: 100 },
|
||||
{ field: 'source_name', title: '来源', align: 'left', width: 100 },
|
||||
{
|
||||
field: 'status', title: '状态', align: 'center', width: 90, templet: function (row) {
|
||||
switch (row.status) {
|
||||
case 0: return '<span style="color:green;">正常</span>';
|
||||
case -1: return '<span style="color:red;">删除</span>';
|
||||
default: return '其它';
|
||||
}
|
||||
return '';
|
||||
}
|
||||
},
|
||||
{ field: 'contact_name', title: '联系人姓名', align: 'left', width: 120 },
|
||||
{ field: 'contact_phone', title: '联系人手机', align: 'left', width: 120 },
|
||||
{ field: 'address', title: '地址', align: 'left', width: 200 },
|
||||
{ field: 'sort', title: '排序', align: 'center', width: 80 },
|
||||
]],
|
||||
skin: 'line',
|
||||
defaultToolbar: []
|
||||
});
|
||||
}
|
||||
|
||||
// 行单击事件( 双击事件为: rowDouble )
|
||||
table.on('row(customer_list)', function (obj) {
|
||||
var data = obj.data; // 获取当前行数据
|
||||
$('#CustomerID').val(data.sid);
|
||||
$('#CustomerName').val(data.name);
|
||||
layer.close(customerLayer);
|
||||
});
|
||||
|
||||
// let sysUserLayer;
|
||||
// let projectUserList = "project_user_list"
|
||||
// $('#selectProjectUser').on('click', function () {
|
||||
// sysUserLayer = layer.open({
|
||||
// type: 1, // page 层类型
|
||||
// area: ['70%', '90%'],
|
||||
// title: '选择数据',
|
||||
// scrollbar: false,
|
||||
// shade: 0.2, // 遮罩透明度
|
||||
// shadeClose: false, // 点击遮罩区域,关闭弹层
|
||||
// maxmin: false, // 允许全屏最小化
|
||||
// anim: 0, // 0-6 的动画形式,-1 不开启
|
||||
// content: '<table id="' + projectUserList + '" lay-filter="' + projectUserList + '"></table>',
|
||||
// success: function (layero, index, that) {
|
||||
// // layero 弹层的最外层元素的 jQuery 对象
|
||||
// // index 弹层的索引值
|
||||
// // that 弹层内部原型链中的 this --- 2.8+
|
||||
// loadUserList(projectUserList);
|
||||
// }
|
||||
// });
|
||||
// });
|
||||
// table.on('row(' + projectUserList + ')', function (obj) {
|
||||
// var data = obj.data; // 获取当前行数据
|
||||
// console.log(data);
|
||||
// $('#ManagerID').val(data.id);
|
||||
// $('#ManagerName').val(data.username);
|
||||
// layer.close(sysUserLayer);
|
||||
// });
|
||||
|
||||
// let applyUserList = "apply_user_list"
|
||||
// $('#selectApplyUser').on('click', function () {
|
||||
// sysUserLayer = layer.open({
|
||||
// type: 1, // page 层类型
|
||||
// area: ['70%', '90%'],
|
||||
// title: '选择数据',
|
||||
// scrollbar: false,
|
||||
// shade: 0.2, // 遮罩透明度
|
||||
// shadeClose: false, // 点击遮罩区域,关闭弹层
|
||||
// maxmin: false, // 允许全屏最小化
|
||||
// anim: 0, // 0-6 的动画形式,-1 不开启
|
||||
// content: '<table id="' + applyUserList + '" lay-filter="' + applyUserList + '"></table>',
|
||||
// success: function (layero, index, that) {
|
||||
// // layero 弹层的最外层元素的 jQuery 对象
|
||||
// // index 弹层的索引值
|
||||
// // that 弹层内部原型链中的 this --- 2.8+
|
||||
// loadUserList(applyUserList);
|
||||
// }
|
||||
// });
|
||||
// });
|
||||
// table.on('row(' + applyUserList + ')', function (obj) {
|
||||
// var data = obj.data; // 获取当前行数据
|
||||
// $('#ApplyUserID').val(data.id);
|
||||
// $('#ApplyUserName').val(data.username);
|
||||
// layer.close(sysUserLayer);
|
||||
// });
|
||||
|
||||
// function loadUserList(elem) {
|
||||
// table.render({
|
||||
// elem: '#' + elem,
|
||||
// url: "/system/user/list",
|
||||
// method: "POST",
|
||||
// headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
// height: 'full',
|
||||
// page: true,
|
||||
// cols: [[
|
||||
// { field: 'email', title: '邮箱', align: 'left', width: 180 },
|
||||
// { field: 'username', title: '用户名', align: 'left', width: 100 },
|
||||
// {
|
||||
// field: 'avatar', title: '头像', align: 'center', width: 90, templet: function (d) {
|
||||
// if (d.avatar === 0 || d.avatar === undefined || d.avatar === '') { return ''; }
|
||||
// if (d.avatar === '/statics/admin/images/avatar.jpg') {
|
||||
// return '<img src="/statics/admin/images/avatar.jpg" width=30 height=30 />';
|
||||
// }
|
||||
// return '<img src="' + d.avatar + '" width=30 height=30 />';
|
||||
// }
|
||||
// },
|
||||
// { field: 'department_name', title: '部门', align: 'left', width: 100 },
|
||||
// { field: 'role_name', title: '角色', align: 'left', width: 100 },
|
||||
// {
|
||||
// field: 'gender', title: '性别', align: 'center', width: 50, templet: function (d) {
|
||||
// if (d.gender == 0) {
|
||||
// return '未知';
|
||||
// } else if (d.gender == 1) {
|
||||
// return '男';
|
||||
// } else if (d.gender == 2) {
|
||||
// return '女';
|
||||
// }
|
||||
// }
|
||||
// },
|
||||
// {
|
||||
// field: 'status', title: '状态', align: 'center', width: 90, templet: function (row) {
|
||||
// switch (row.status) {
|
||||
// case 0: return '正常';
|
||||
// case -1: return '删除';
|
||||
// default: return '其它';
|
||||
// }
|
||||
// return '';
|
||||
// }
|
||||
// },
|
||||
// ]],
|
||||
// skin: 'line',
|
||||
// defaultToolbar: []
|
||||
// });
|
||||
// }
|
||||
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
@@ -1,262 +0,0 @@
|
||||
{{template "header" .}}
|
||||
|
||||
<!-- 工具栏 -->
|
||||
<script id="toolbar" type="text/html">
|
||||
{{ genBtn .AuthorizeMenus "add"}}
|
||||
<button type="button" lay-event="search" lay-on="search" class="layui-btn layui-btn-primary layui-btn-sm">
|
||||
<i class="layui-icon layui-icon-search"></i>
|
||||
</button>
|
||||
</script>
|
||||
|
||||
<!-- 操作栏 -->
|
||||
<script type="text/html" id="actionBox">
|
||||
{{ genLink .AuthorizeMenus "edit"}}
|
||||
</script>
|
||||
|
||||
<div class="search-layer" id="search-layer" style="display: none;">
|
||||
<div class="layui-form layui-row">
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">开始时间</label>
|
||||
<input type="text" name="timeBegin" id="timeBegin" placeholder="yyyy-MM-dd" readonly
|
||||
value="{{ yearBegin }}" class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">结束时间</label>
|
||||
<input type="text" name="timeEnd" id="timeEnd" placeholder="yyyy-MM-dd" readonly value="{{ monthEnd }}"
|
||||
class="layui-input" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">项目名称</label>
|
||||
<input type="text" name="title" id="title" placeholder="请输入项目名称" autocomplete="off" class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form layui-row">
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">项目编号</label>
|
||||
<input type="text" name="sid" id="sid" placeholder="请输入项目编号" autocomplete="off" class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">客户名称</label>
|
||||
<input type="text" name="customer_name" id="customer_name" placeholder="请输入客户名称" autocomplete="off"
|
||||
class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-col-xs12 layui-col-sm12 layui-col-md4">
|
||||
<div class="layui-form-column">
|
||||
<label class="tips">项目状态</label>
|
||||
<select name="status" id="status">
|
||||
<option value="9999">请选择</option>
|
||||
{{range.Statuses}}
|
||||
<option value="{{.Value}}">{{.Name}}</option>
|
||||
{{end}}
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-panel">
|
||||
<table id="tablelist" lay-filter="tablelist"></table>
|
||||
</div>
|
||||
|
||||
{{define "js"}}
|
||||
<script>
|
||||
layui.use(['jquery', 'table', 'form', 'laydate', 'util'], function () {
|
||||
let $ = layui.jquery;
|
||||
let table = layui.table;
|
||||
let form = layui.form;
|
||||
let util = layui.util;
|
||||
let laydate = layui.laydate;
|
||||
|
||||
/**开始时间 */
|
||||
laydate.render({
|
||||
elem: '#timeBegin',
|
||||
type: 'datetime',
|
||||
value: '{{ yearBegin }}',
|
||||
ready: function (date) {
|
||||
this.dateTime.hours = 0;
|
||||
this.dateTime.minutes = 0;
|
||||
this.dateTime.seconds = 0;
|
||||
}
|
||||
});
|
||||
|
||||
/**截止时间 */
|
||||
laydate.render({
|
||||
elem: '#timeEnd',
|
||||
type: 'datetime',
|
||||
value: '{{ monthEnd }}',
|
||||
ready: function (date) {
|
||||
this.dateTime.hours = 23;
|
||||
this.dateTime.minutes = 59;
|
||||
this.dateTime.seconds = 59;
|
||||
}
|
||||
});
|
||||
|
||||
// 加载列表
|
||||
table.render({
|
||||
elem: '#tablelist',
|
||||
url: "/project/list",
|
||||
method: "POST",
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
where: getQueryParams(),
|
||||
height: function () {
|
||||
return $(window).height() - 22;
|
||||
},
|
||||
page: true,
|
||||
limit: 15,
|
||||
limits: [15, 30, 45, 60, 75, 90],
|
||||
cols: [[
|
||||
{ field: 'name', title: '项目名称', align: 'left', width: 200, fixed: 'left' },
|
||||
{
|
||||
field: 'status_name', title: '项目状态', align: 'left', fixed: 'left', width: 90, templet: function (d) {
|
||||
return '<span style="display:inline-block;color:green">' + d.status_name + '</span>';
|
||||
}
|
||||
},
|
||||
{ field: 'sid', title: '项目编号', align: 'left', width: 170 },
|
||||
{ field: 'customer_name', title: '客户名称', align: 'left', width: 200 },
|
||||
{ field: 'total_money', title: '总金额', align: 'left', width: 120 },
|
||||
{ field: 'start_at', title: '项目开始时间', align: 'center', width: 160, templet: function (d) { return !d.created_at ? '' : util.toDateString(d.created_at) } },
|
||||
{ field: 'end_at', title: '项目结束时间', align: 'center', width: 160, templet: function (d) { return !d.created_at ? '' : util.toDateString(d.created_at) } },
|
||||
{ field: 'apply_name', title: '申请人', align: 'left', width: 120 },
|
||||
{ field: 'apply_at', title: '申请时间', align: 'center', width: 160, templet: function (d) { return !d.created_at ? '' : util.toDateString(d.created_at) } },
|
||||
{ field: 'manager_name', title: '项目经理', align: 'left', width: 90 },
|
||||
{ field: 'member_names', title: '项目成员', align: 'left', width: 160 },
|
||||
{ field: 'sort', title: '排序', align: 'center', width: 80 },
|
||||
{ field: 'created_at', title: '创建时间', align: 'center', width: 160, templet: function (d) { return !d.created_at ? '' : util.toDateString(d.created_at) } },
|
||||
{ field: 'created_name', title: '创建人', align: 'center', width: 100 },
|
||||
{ field: 'updated_at', title: '更新时间', align: 'center', width: 160, templet: function (d) { return !d.updated_at ? '' : util.toDateString(d.updated_at) } },
|
||||
{ field: 'updated_name', title: '更新人', align: 'center', width: 100 },
|
||||
{ title: '操作', toolbar: '#actionBox', align: 'center', fixed: 'right', width: 100 },
|
||||
]],
|
||||
skin: 'grid',
|
||||
toolbar: '#toolbar',
|
||||
defaultToolbar: [{
|
||||
title: '刷新',
|
||||
layEvent: 'refresh',
|
||||
icon: 'layui-icon-refresh',
|
||||
}, 'filter', 'exports'],
|
||||
request: {
|
||||
pageName: 'page',
|
||||
limitName: 'rows'
|
||||
}
|
||||
});
|
||||
|
||||
// 工具栏
|
||||
table.on('toolbar(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'add': add(); break;
|
||||
case 'search': search(); break;
|
||||
case 'refresh': refresh(); break;
|
||||
}
|
||||
});
|
||||
|
||||
function add(obj) {
|
||||
layer.open({
|
||||
type: 2,
|
||||
// offset: 'r',
|
||||
// anim: 'slideLeft',
|
||||
title: '新增',
|
||||
shade: 0.1,
|
||||
area: ['99%', '98%'],
|
||||
content: "/project/add"
|
||||
});
|
||||
}
|
||||
|
||||
function search() {
|
||||
layer.open({
|
||||
type: 1,
|
||||
offset: '20px',
|
||||
title: '搜索',
|
||||
content: $('#search-layer'), // 捕获的元素
|
||||
shade: 0.1,
|
||||
shadeClose: false,
|
||||
scrollbar: false,
|
||||
resize: false,
|
||||
move: false,
|
||||
skin: 'search-layer-open',
|
||||
area: ['50%', '350px'],
|
||||
btn: ['搜索', '重置'],
|
||||
btn1: function (index, layero) {
|
||||
search_btn();
|
||||
layer.close(index);
|
||||
},
|
||||
btn2: function (index, layero) {
|
||||
$('#timeBegin').val(formatDate(getCurrentYearStart(), 'YYYY-MM-DD HH:mm:ss'));
|
||||
$('#timeEnd').val(formatDate(getCurrentMonthEnd(), 'YYYY-MM-DD HH:mm:ss'));
|
||||
$('#title').val('');
|
||||
$('#sid').val('');
|
||||
$('#customer_name').val('');
|
||||
$('#status').val(9999);
|
||||
form.render('select');
|
||||
return false;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function refresh() {
|
||||
table.reload('tablelist');
|
||||
}
|
||||
|
||||
// 表格项操作按钮
|
||||
table.on('tool(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'edit': edit(obj); break;
|
||||
}
|
||||
});
|
||||
|
||||
function edit(obj) {
|
||||
layer.open({
|
||||
type: 2,
|
||||
// offset: 'r',
|
||||
// anim: 'slideLeft',
|
||||
title: '修改',
|
||||
shade: 0.1,
|
||||
area: ['99%', '98%'],
|
||||
content: "/project/edit?id=" + obj.data['sid']
|
||||
});
|
||||
}
|
||||
|
||||
// 搜索条件
|
||||
function getQueryParams() {
|
||||
return {
|
||||
timeBegin: $('#timeBegin').val(),
|
||||
timeEnd: $('#timeEnd').val(),
|
||||
status: $('#status').val(),
|
||||
category: $('#category').val(),
|
||||
source: $('#source').val(),
|
||||
title: $('#title').val()
|
||||
};
|
||||
}
|
||||
|
||||
// 搜索
|
||||
function search_btn() {
|
||||
// form.on('submit(user-query)', function (data) {
|
||||
// table.reload('tablelist', {
|
||||
// where: getQueryParams(),
|
||||
// page: {
|
||||
// curr: 1
|
||||
// }
|
||||
// })
|
||||
// return false;
|
||||
// });
|
||||
table.reload('tablelist', {
|
||||
where: getQueryParams(),
|
||||
page: {
|
||||
curr: 1
|
||||
}
|
||||
})
|
||||
}
|
||||
});
|
||||
</script>
|
||||
{{end}}
|
||||
|
||||
{{template "footer" .}}
|
||||
@@ -187,7 +187,7 @@
|
||||
|
||||
function getCategory() {
|
||||
$.ajax({
|
||||
url: "/system/category/data?type=xmselect_tree",
|
||||
url: "/system/category/data?type=xm_select_tree",
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
|
||||
@@ -9,7 +9,7 @@
|
||||
</script>
|
||||
|
||||
<script type="text/html" id="actionBox">
|
||||
{{ genLink .AuthorizeMenus "edit" "refresh"}}
|
||||
{{ genLink .AuthorizeMenus "edit" "refresh_cache"}}
|
||||
</script>
|
||||
|
||||
<div class="search-layer" id="search-layer" style="display: none;">
|
||||
@@ -134,7 +134,7 @@
|
||||
table.on('tool(tablelist)', function (obj) {
|
||||
switch (obj.event) {
|
||||
case 'edit': edit(obj); break;
|
||||
case 'refresh': refresh(obj); break;
|
||||
case 'refresh_cache': refresh_cache(obj); break;
|
||||
}
|
||||
});
|
||||
|
||||
@@ -148,10 +148,10 @@
|
||||
});
|
||||
}
|
||||
|
||||
function refresh(obj) {
|
||||
function refresh_cache(obj) {
|
||||
layer.confirm('确定要刷新数据吗?', { title: '提示' }, function (index, layero) {
|
||||
$.ajax({
|
||||
url: '/system/config/refresh',
|
||||
url: '/system/config/refresh_cache',
|
||||
type: 'post',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
dataType: 'json',
|
||||
|
||||
@@ -150,7 +150,7 @@
|
||||
|
||||
function getDepartmentTree() {
|
||||
$.ajax({
|
||||
url: "/system/department/data?type=xmselect_tree",
|
||||
url: "/system/department/data?type=xm_select_tree",
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
|
||||
@@ -96,7 +96,6 @@
|
||||
case -1: return '<span style="color: red">删除</span>';
|
||||
default: return '其它';
|
||||
}
|
||||
return '';
|
||||
}
|
||||
},
|
||||
{ field: 'created_at', title: '创建时间', width: 160, align: 'center', templet: function (d) { return (!d.created_at || d.id === 0) ? '' : util.toDateString(d.created_at) } },
|
||||
|
||||
@@ -225,7 +225,7 @@
|
||||
|
||||
function getMenuTree() {
|
||||
$.ajax({
|
||||
url: "/system/menu/data?type=xmselect_tree",
|
||||
url: "/system/menu/data?type=xm_select_tree",
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
|
||||
@@ -159,7 +159,7 @@
|
||||
|
||||
function getRoleTree() {
|
||||
$.ajax({
|
||||
url: "/system/role/data?type=xmselect_tree",
|
||||
url: "/system/role/data?type=xm_select_tree",
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
|
||||
@@ -202,7 +202,7 @@
|
||||
|
||||
function getDepartmentTree() {
|
||||
$.ajax({
|
||||
url: "/system/department/data?type=xmselect_tree",
|
||||
url: "/system/department/data?type=xm_select_tree",
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
@@ -239,7 +239,7 @@
|
||||
|
||||
function getRoleTree() {
|
||||
$.ajax({
|
||||
url: "/system/role/data?type=xmselect_tree",
|
||||
url: "/system/role/data?type=xm_select_tree",
|
||||
type: 'post',
|
||||
dataType: 'json',
|
||||
headers: { 'X-CSRF-Token': $('#csrf_token').val() },
|
||||
|
||||
Reference in New Issue
Block a user