[xzgl]企业证书管理

This commit is contained in:
2025-06-25 22:21:58 +08:00
parent 71ad1c981c
commit 1d6dd6c067
8 changed files with 276 additions and 4 deletions

View File

@ -16,14 +16,13 @@ class Service extends Plugin
'name' => '行政管理',
'subs' => [
['name' => '员工档案', 'icon' => 'layui-icon layui-icon-group', 'url' => 'xzgl/user/index'],
['name' => '通知公告', 'icon' => 'layui-icon layui-icon-cols', 'url' => 'xzgl/notice/index'],
]
],
[
'name' => '证书管理',
'subs' => [
['name' => '证书管理', 'icon' => 'layui-icon layui-icon-auz', 'url' => 'xzgl/staff_cert/index'],
['name' => '证书管理', 'icon' => 'layui-icon layui-icon-auz', 'url' => 'xzgl/company_cert/index'],
['name' => '员工证书管理', 'icon' => 'layui-icon layui-icon-auz', 'url' => 'xzgl/staff_cert/index'],
['name' => '企业证书管理', 'icon' => 'layui-icon layui-icon-auz', 'url' => 'xzgl/company_cert/index'],
]
]
];

View File

@ -0,0 +1,87 @@
<?php
namespace app\xzgl\controller;
use app\xzgl\model\XzglCompanyCert;
use think\admin\Controller;
use think\admin\helper\QueryHelper;
use think\admin\model\SystemBase;
/**
* 企业证书管理
*/
class CompanyCert extends Controller
{
/**
* 企业证书管理
* @auth true
* @menu true
* @return void
*/
public function index()
{
$this->title = '企业证书管理';
XzglCompanyCert::mQuery()->layTable(function () {
$this->levels = SystemBase::items('企业证书等级');
}, static function (QueryHelper $query) {
$query->like('name')->dateBetween('valid_before')->equal('level');
});
}
/**
* 查看企业证书
* @auth false
* @return void
*/
public function view()
{
XzglCompanyCert::mForm('view');
}
/**
* 添加企业证书
* @auth true
* @return void
*/
public function add()
{
XzglCompanyCert::mForm('form');
}
/**
* 编辑企业证书
* @auth true
* @return void
*/
public function edit()
{
XzglCompanyCert::mForm('form');
}
protected function _form_filter(&$vo)
{
if ($this->request->isPost()) {
if (empty($vo['valid_before'])) {
unset($vo['valid_before']);
}
// if (empty($vo['valid_after'])) {
// unset($vo['valid_after']);
// }
if (empty($vo['id'])) {
$vo['create_by'] = session('user.id');
}
$vo['update_by'] = session('user.id');
} else {
$this->levels = SystemBase::items('企业证书等级');
}
}
/**
* 删除企业证书
* @return void
*/
public function remove()
{
XzglCompanyCert::mDelete();
}
}

View File

@ -0,0 +1,37 @@
<?php
namespace app\xzgl\model;
use think\admin\Model;
use think\admin\model\SystemBase;
use think\db\Query;
class XzglCompanyCert extends Model
{
protected $createTime = 'create_at';
protected $updateTime = 'update_at';
protected $oplogName = '企业证书';
protected $oplogType = '企业证书管理';
protected $globalScope = ['notDeleted'];
protected $append = ['level_name'];
public function scopeDeleted(Query $query): void
{
$query->where('is_deleted', '=', 1);
}
public function scopeNotDeleted(Query $query): void
{
$query->where('is_deleted', '=', 0);
}
public function getLevelNameAttr($value, $data)
{
$levels = SystemBase::items('企业证书等级');
if (isset($levels[$data['level']])) {
return $levels[$data['level']]['name'];
} else {
return $data['level'];
}
}
}

View File

@ -8,6 +8,10 @@ use think\model\relation\HasOne;
class XzglProfile extends Model
{
protected $createTime = 'create_at';
protected $updateTime = 'update_at';
protected $oplogName = '人员资料';
protected $oplogType = '人员资料管理';
public function user(): HasOne
{
return $this->hasOne(StaffUser::class, 'id', 'id')->with(['dept', 'sys_user']);

View File

@ -0,0 +1,63 @@
<form action="{:sysuri()}" method="post" data-auto="true" class="layui-form layui-card" data-table-id="UserTable">
<div class="layui-card-body padding-left-40">
<fieldset class="layui-bg-gray">
<legend><b class="layui-badge think-bg-violet">基础信息</b></legend>
<div class="layui-form-item">
<label class="layui-form-label">证书名称</label>
<div class="layui-input-block">
<input type="text" class="layui-input" name="name" required value='{$vo.name|default=""}' placeholder="请填写证书名称">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">证书等级</label>
<div class="layui-input-block">
<select name="level" required>
<option value="">{:lang('请选择证书等级')}</option>
{foreach $levels as $key => $level}{if (isset($vo.level) and $key eq $vo.level)}
<option selected value="{$key}">{$level.name}</option>
{else}
<option value="{$key}">{$level.name}</option>
{/if}{/foreach}
</select>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">有效期截至</label>
<div class="layui-input-block">
<input lay-date type="text" class="layui-input" name="valid_before" value='{$vo.valid_before|default=""}' placeholder="请选择有效期截至时间">
</div>
</div>
</fieldset>
<fieldset class="layui-bg-gray">
<legend><b class="layui-badge think-bg-violet">备注</b></legend>
<div class="layui-form-item">
<label class="layui-form-label">备注</label>
<div class="layui-input-block">
<textarea class="layui-textarea" name="content" value='{$vo.content|default=""}' placeholder="请输入备注">
</textarea>
</div>
</div>
</fieldset>
</div>
<div class="hr-line-dashed"></div>
{notempty name='$get.id'}<input type='hidden' value='{$get.id}' name='id'>{/notempty}
<div class="layui-form-item text-center">
<button class="layui-btn" type='submit'>{:lang('保存数据')}</button>
<button class="layui-btn layui-btn-danger" type='button' data-confirm="{:lang('确定要取消编辑吗?')}" data-close>{:lang('取消编辑')}</button>
</div>
</form>
<script>
$(function () {
layui.use(['form', 'laydate'], function () {
const Form = layui.form;
const Laydate = layui.laydate;
$('input[lay-date]').each(function (index, element) {
Laydate.render({
elem: element,
trigger: 'click'
});
})
})
})
</script>

View File

@ -0,0 +1,47 @@
{extend name='table'}
{block name="button"}
<!--{if auth("add")}-->
<button data-modal='{:url("add")}' data-title="{:lang('添加企业证书')}" class='layui-btn layui-btn-sm layui-btn-primary'>{:lang('新 增')}</button>
<!--{/if}-->
{/block}
{block name="content"}
<div class="think-box-shadow" style="flex: 4">
{include file="company_cert/index_search"}
<table class="layui-hide" id="CertTable" data-url="{:request()->url()}" data-target-search="form.form-search" lay-filter="CertTable"></table>
</div>
<script type="text/html" id="ToolbarTpl">
<div class="layui-btn-container">
<!--{if auth("edit")}-->
<a class="layui-btn layui-btn-xs" data-modal="{:url('edit')}?id={{d.id}}" data-title="编辑企业证书">{:lang('编 辑')}</a>
<!--{/if}-->
<!--{if auth("remove")}-->
<a class="layui-btn layui-btn-danger layui-btn-xs" data-confirm="{:lang('确定要删除该企业证书吗?')}" data-action="{:url('remove')}" data-value="id#{{d.id}}">{:lang('删除证书')}</a>
<!--{/if}-->
</div>
</script>
<script>
$(function () {
$('#CertTable').layTable({
height: 'full',
sort: ['create_at', 'desc'],
cols: [[
{ field: 'name', title: '企业证书名称', width: 200 },
{ field: 'level_name', title: '证书等级' },
{ field: 'valid_before', title: '有效期截至', width: 200, sort: true },
{ field: 'create_at', title: '创建时间', width: 200, sort: true },
{ fixed: "right", title: "操作", width: 200, align: "center", toolbar: "#ToolbarTpl"}
]],
page: true
})
layui.use(['form', 'table'], function () {
const Table = layui.table;
const Form = layui.form;
Table.on('tool(CertTable)', function (obj) {
console.log(obj);
})
});
})
</script>
{/block}

View File

@ -0,0 +1,35 @@
<fieldset>
<legend>{:lang('条件搜索')}</legend>
<form class="layui-form layui-form-pane form-search" action="{:request()->url()}" onsubmit="return false" method="post" autocomplete="off">
<div class="layui-form-item layui-inline">
<label class="layui-form-label">{:lang('名称')}</label>
<label class="layui-input-inline">
<input name="name" value="{$get.name|default=''}" placeholder="{:lang('名称')}" class="layui-input">
</label>
</div>
<div class="layui-form-item layui-inline">
<label class="layui-form-label">{:lang('证书等级')}</label>
<label class="layui-input-inline">
<select name="level">
<option value="">{:lang('请选择证书等级')}</option>
{foreach $levels as $key => $level}{if ($key eq input('get.type'))}
<option selected value="{$key}">{$level.name}</option>
{else}
<option value="{$key}">{$level.name}</option>
{/if}{/foreach}
</select>
</label>
</div>
<div class="layui-form-item layui-inline">
<label class="layui-form-label">{:lang('有效期截至时间')}</label>
<div class="layui-input-inline">
<input data-date-range name="valid_before" value="{$get.valid_before|default=''}" placeholder="{:lang('请选择有效期截至时间')}" class="layui-input">
</div>
</div>
<div class="layui-form-item layui-inline">
<button class="layui-btn layui-btn-primary"><i class="layui-icon">&#xe615;</i> {:lang('搜 索')}</button>
</div>
</form>
</fieldset>

View File

@ -4,7 +4,7 @@
<div class="layui-form-item layui-inline">
<label class="layui-form-label">{:lang('内容')}</label>
<label class="layui-input-inline">
<input name="name" value="{$get.content|default=''}" placeholder="{:lang('内容')}" class="layui-input">
<input name="name" value="{$get.name|default=''}" placeholder="{:lang('内容')}" class="layui-input">
</label>
</div>