363 lines
9.7 KiB
PHP
363 lines
9.7 KiB
PHP
{include file="public/header" /}
|
|
<div class="material-tabs">
|
|
<div class="tabs-header">
|
|
<div class="tab active" data-type="image">图片</div>
|
|
<div class="tab" data-type="video">视频</div>
|
|
<div class="tab" data-type="file">文件</div>
|
|
</div>
|
|
<div class="tabs-content">
|
|
<!-- 图片Tab内容 -->
|
|
<div class="tab-panel" id="tab-image" style="display:block;">
|
|
<div class="material-center">
|
|
<!-- 左侧分组树 -->
|
|
<div class="sidebar">
|
|
<ul class="group-list" id="groupList">
|
|
<li class="active">全部</li>
|
|
<!-- ... -->
|
|
</ul>
|
|
<div class="sidebar-header">
|
|
<button class="layui-btn layui-btn-normal" onclick="addGroup()">添加分组</button>
|
|
</div>
|
|
</div>
|
|
<!-- 右侧内容 -->
|
|
<div class="main-content">
|
|
<div class="toolbar">
|
|
<div class="material-actions">
|
|
<button class="layui-btn layui-btn-normal" id="uploadBtn">上传</button>
|
|
<button class="layui-btn layui-btn-danger" id="batchDeleteBtn">批量删除</button>
|
|
</div>
|
|
<button class="layui-btn" onclick="moveMaterial()">移动</button>
|
|
<label class="select-all">
|
|
<input type="checkbox" id="selectAll" /> 全选
|
|
</label>
|
|
</div>
|
|
<div class="image-grid" id="imageGrid">
|
|
<div class="image-item">
|
|
<input type="checkbox" class="img-checkbox" />
|
|
<img src="https://placekitten.com/120/120" alt="示例图片" />
|
|
<div class="img-name">示例图片.jpg</div>
|
|
<div class="img-actions">
|
|
<button class="layui-btn layui-btn-xs" onclick="renameImg(this)">重命名</button>
|
|
<button class="layui-btn layui-btn-xs layui-btn-primary" onclick="viewImg(this)">查看</button>
|
|
<button class="layui-btn layui-btn-xs layui-btn-warm" onclick="copyUrl(this)">地址</button>
|
|
</div>
|
|
</div>
|
|
<!-- ... -->
|
|
</div>
|
|
<div class="pagination">
|
|
<button class="layui-btn layui-btn-xs">上一页</button>
|
|
<span>1 / 10</span>
|
|
<button class="layui-btn layui-btn-xs">下一页</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- 视频Tab内容 -->
|
|
<div class="tab-panel" id="tab-video" style="display:none;">
|
|
<div class="material-center">
|
|
<div style="padding:40px;text-align:center;color:#bbb;">这里是视频管理内容</div>
|
|
</div>
|
|
</div>
|
|
<!-- 文件Tab内容 -->
|
|
<div class="tab-panel" id="tab-file" style="display:none;">
|
|
<div class="material-center">
|
|
<div style="padding:40px;text-align:center;color:#bbb;">这里是文件管理内容</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<script>
|
|
// Tab切换
|
|
document.querySelectorAll('.material-tabs .tab').forEach(function (tab) {
|
|
tab.onclick = function () {
|
|
document.querySelectorAll('.material-tabs .tab').forEach(t => t.classList.remove('active'));
|
|
tab.classList.add('active');
|
|
var type = tab.getAttribute('data-type');
|
|
document.querySelectorAll('.tab-panel').forEach(panel => panel.style.display = 'none');
|
|
document.getElementById('tab-' + type).style.display = 'block';
|
|
}
|
|
});
|
|
|
|
// 分组高亮切换
|
|
document.getElementById('groupList').addEventListener('click', function (e) {
|
|
if (e.target.tagName === 'LI' || e.target.closest('li')) {
|
|
document.querySelectorAll('#groupList li').forEach(li => li.classList.remove('active'));
|
|
(e.target.tagName === 'LI' ? e.target : e.target.closest('li')).classList.add('active');
|
|
// TODO: 根据分组加载图片
|
|
}
|
|
});
|
|
|
|
// 其它功能函数(示例)
|
|
function addGroup() {
|
|
alert('添加分组功能待实现');
|
|
}
|
|
function uploadMaterial() {
|
|
alert('上传功能待实现');
|
|
}
|
|
function batchDelete() {
|
|
alert('批量删除功能待实现');
|
|
}
|
|
function moveMaterial() {
|
|
alert('移动功能待实现');
|
|
}
|
|
</script>
|
|
|
|
<style>
|
|
.material-tabs {
|
|
width: 100%;
|
|
height: 100vh;
|
|
background: #f6f7fb;
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
|
|
.tabs-header {
|
|
display: flex;
|
|
border-bottom: 2px solid #e6e6e6;
|
|
background: #fff;
|
|
padding-left: 32px;
|
|
height: 52px;
|
|
align-items: center;
|
|
}
|
|
|
|
.tab {
|
|
padding: 0 32px;
|
|
height: 52px;
|
|
line-height: 52px;
|
|
font-size: 16px;
|
|
color: #666;
|
|
cursor: pointer;
|
|
position: relative;
|
|
transition: color 0.2s;
|
|
}
|
|
|
|
.tab.active {
|
|
color: #409eff;
|
|
font-weight: bold;
|
|
}
|
|
|
|
.tab.active::after {
|
|
content: '';
|
|
position: absolute;
|
|
left: 16px;
|
|
right: 16px;
|
|
bottom: 0;
|
|
height: 3px;
|
|
background: #409eff;
|
|
border-radius: 2px 2px 0 0;
|
|
}
|
|
|
|
.tabs-content {
|
|
flex: 1;
|
|
width: 100%;
|
|
overflow: auto;
|
|
background: #f6f7fb;
|
|
}
|
|
|
|
.tab-panel {
|
|
width: 100%;
|
|
/* height: 100%; */
|
|
display: none;
|
|
}
|
|
|
|
.tab-panel:target,
|
|
.tab-panel.active {
|
|
display: block;
|
|
}
|
|
|
|
.material-center {
|
|
display: flex;
|
|
height: 100%;
|
|
background: #fafbfc;
|
|
font-family: "Microsoft YaHei", Arial, sans-serif;
|
|
}
|
|
|
|
.sidebar {
|
|
width: 220px;
|
|
background: #fff;
|
|
border-right: 1px solid #e6e6e6;
|
|
display: flex;
|
|
flex-direction: column;
|
|
padding: 0;
|
|
}
|
|
|
|
.sidebar-header {
|
|
display: flex;
|
|
font-size: 16px;
|
|
font-weight: bold;
|
|
color: #333;
|
|
border-top: 1px solid #f0f0f0;
|
|
justify-content: center;
|
|
padding: 20px 0;
|
|
}
|
|
|
|
.add-group-btn {
|
|
background: #409eff;
|
|
color: #fff;
|
|
border: none;
|
|
border-radius: 50%;
|
|
width: 26px;
|
|
height: 26px;
|
|
font-size: 18px;
|
|
cursor: pointer;
|
|
transition: background 0.2s;
|
|
}
|
|
|
|
.add-group-btn:hover {
|
|
background: #66b1ff;
|
|
}
|
|
|
|
.group-list {
|
|
list-style: none;
|
|
margin: 0;
|
|
padding: 10px 0 0 0;
|
|
flex: 1;
|
|
}
|
|
|
|
.group-list li {
|
|
padding: 10px 24px;
|
|
color: #444;
|
|
cursor: pointer;
|
|
display: flex;
|
|
align-items: center;
|
|
border-radius: 4px 0 0 4px;
|
|
transition: background 0.2s, color 0.2s;
|
|
font-size: 15px;
|
|
}
|
|
|
|
.group-list li .iconfont {
|
|
font-size: 16px;
|
|
margin-right: 8px;
|
|
color: #b2b2b2;
|
|
}
|
|
|
|
.group-list li.active,
|
|
.group-list li:hover {
|
|
background: #f2f6fc;
|
|
color: #409eff;
|
|
}
|
|
|
|
.main-content {
|
|
flex: 1;
|
|
padding: 32px 36px;
|
|
display: flex;
|
|
flex-direction: column;
|
|
min-width: 0;
|
|
}
|
|
|
|
.toolbar {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 12px;
|
|
margin-bottom: 18px;
|
|
}
|
|
|
|
.select-all {
|
|
margin-left: auto;
|
|
font-size: 14px;
|
|
color: #888;
|
|
user-select: none;
|
|
}
|
|
|
|
.image-grid {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: 22px;
|
|
min-height: 320px;
|
|
}
|
|
|
|
.image-item {
|
|
width: 140px;
|
|
background: #fff;
|
|
border: 1px solid #eaeaea;
|
|
border-radius: 8px;
|
|
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
padding: 14px 8px 10px 8px;
|
|
position: relative;
|
|
cursor: pointer;
|
|
transition: box-shadow 0.2s, border 0.2s;
|
|
}
|
|
|
|
.image-item:hover {
|
|
border: 1px solid #409eff;
|
|
box-shadow: 0 4px 16px rgba(64, 158, 255, 0.10);
|
|
}
|
|
|
|
.image-item img {
|
|
width: 120px;
|
|
height: 120px;
|
|
object-fit: cover;
|
|
border-radius: 4px;
|
|
margin-bottom: 8px;
|
|
background: #f5f7fa;
|
|
border: 1px solid #f0f0f0;
|
|
}
|
|
|
|
.img-name {
|
|
font-size: 14px;
|
|
color: #666;
|
|
text-align: center;
|
|
margin-bottom: 6px;
|
|
word-break: break-all;
|
|
height: 32px;
|
|
line-height: 16px;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.img-checkbox {
|
|
position: absolute;
|
|
top: 12px;
|
|
left: 12px;
|
|
transform: scale(1.2);
|
|
}
|
|
|
|
.img-actions {
|
|
display: none;
|
|
margin-top: 6px;
|
|
text-align: center;
|
|
gap: 4px;
|
|
}
|
|
|
|
.image-item.active .img-actions {
|
|
display: flex;
|
|
justify-content: center;
|
|
}
|
|
|
|
.img-actions .layui-btn-xs {
|
|
margin: 0 2px;
|
|
font-size: 12px;
|
|
padding: 0 10px;
|
|
}
|
|
|
|
.pagination {
|
|
margin-top: 28px;
|
|
text-align: center;
|
|
font-size: 15px;
|
|
color: #888;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
gap: 12px;
|
|
}
|
|
|
|
@media (max-width: 900px) {
|
|
.main-content {
|
|
padding: 12px 4px;
|
|
}
|
|
|
|
.image-item {
|
|
width: 100px;
|
|
padding: 8px 4px 8px 4px;
|
|
}
|
|
|
|
.image-item img {
|
|
width: 80px;
|
|
height: 80px;
|
|
}
|
|
}
|
|
</style>
|
|
{include file="public/tail" /} |