mirror of
https://gitee.com/zoujingli/ThinkAdmin.git
synced 2025-04-06 03:58:04 +08:00
168 lines
4.6 KiB
HTML
168 lines
4.6 KiB
HTML
{extend name='admin@public/content'}
|
|
|
|
{block name="button"}
|
|
<button data-open="{:url('add')}" class='layui-btn layui-btn-sm'>添加图文</button>
|
|
{/block}
|
|
|
|
{block name='content'}
|
|
|
|
<div id="news_box">
|
|
{foreach $list as $vo}
|
|
<div class="news_item">
|
|
<div class='news_tools hide'>
|
|
<a data-phone-view="{:url('@wechat/review')}?type=news&content={$vo.id}" href='javascript:void(0)'>预览</a>
|
|
<a data-modal="{:url('push')}?id={$vo.id}" href='javascript:void(0)'>推送</a>
|
|
<a data-open='{:url("edit")}?id={$vo.id}' href='javascript:void(0)'>编辑</a>
|
|
<a data-news-del="{$vo.id}" href='javascript:void(0)'>删除</a>
|
|
</div>
|
|
{foreach $vo.articles as $k => $v}
|
|
{if $k < 1}
|
|
<div data-tips-image='{$v.local_url}' class='news_articel_item' style='background-image:url("{$v.local_url}")'>
|
|
{if $v.title}<p>{$v.title}</p>{/if}
|
|
</div>
|
|
<div class="hr-line-dashed"></div>
|
|
{else}
|
|
<div class='news_articel_item other'>
|
|
<div class='right-text'>{$v.title}</div>
|
|
<div data-tips-image='{$v.local_url}' class='left-image' style='background-image:url("{$v.local_url}");'></div>
|
|
</div>
|
|
<div class="hr-line-dashed"></div>
|
|
{/if}
|
|
{/foreach}
|
|
</div>
|
|
{/foreach}
|
|
<div style="clear:both"></div>
|
|
{if empty($list)}
|
|
<p class="help-block text-center well">没 有 记 录 哦!</p>
|
|
{/if}
|
|
</div>
|
|
{if isset($page)}<p>{$page|raw}</p>{/if}
|
|
|
|
{/block}
|
|
|
|
{block name='script'}
|
|
<script>
|
|
|
|
$('body').on('mouseenter', '.news_item', function () {
|
|
$(this).find('.news_tools').removeClass('hide');
|
|
}).on('mouseleave', '.news_item', function () {
|
|
$(this).find('.news_tools').addClass('hide');
|
|
});
|
|
|
|
require(['jquery.masonry'], function (Masonry) {
|
|
var container = document.querySelector('#news_box');
|
|
var msnry = new Masonry(container, {itemSelector: '.news_item', columnWidth: 0});
|
|
msnry.layout();
|
|
$('body').on('click', '[data-news-del]', function () {
|
|
var self = this;
|
|
var dialogIndex = $.msg.confirm('确定要删除图文吗?', function () {
|
|
$.form.load('{:url("del")}', {
|
|
field: 'delete',
|
|
value: 0,
|
|
id: self.getAttribute('data-news-del')
|
|
}, 'post', function (ret) {
|
|
if (ret.code) {
|
|
$(self).parents('.news_item').remove();
|
|
return $.msg.success(ret.msg), msnry.layout(), false;
|
|
}
|
|
return $.msg.error(ret.msg), false;
|
|
});
|
|
$.msg.close(dialogIndex);
|
|
});
|
|
});
|
|
});
|
|
|
|
</script>
|
|
{/block}
|
|
|
|
{block name="style"}
|
|
<style>
|
|
|
|
#news_box {
|
|
position: relative;
|
|
}
|
|
|
|
#news_box .news_item {
|
|
top: 0;
|
|
left: 0;
|
|
padding: 5px;
|
|
margin: 10px;
|
|
width: 300px;
|
|
position: relative;
|
|
border: 1px solid #ccc;
|
|
box-sizing: content-box;
|
|
}
|
|
|
|
#news_box .news_item .news_articel_item {
|
|
width: 100%;
|
|
height: 150px;
|
|
overflow: hidden;
|
|
position: relative;
|
|
background-size: 100%;
|
|
background-position: center center;
|
|
}
|
|
|
|
#news_box .news_item .news_articel_item p {
|
|
bottom: 0;
|
|
width: 100%;
|
|
color: #fff;
|
|
padding: 5px;
|
|
max-height: 5em;
|
|
font-size: 12px;
|
|
overflow: hidden;
|
|
position: absolute;
|
|
text-overflow: ellipsis;
|
|
background: rgba(0, 0, 0, 0.7);
|
|
}
|
|
|
|
#news_box .news_item .news_articel_item.other {
|
|
height: 50px;
|
|
padding: 5px 0;
|
|
}
|
|
|
|
#news_box .news_item .news_articel_item .left-image {
|
|
width: 50px;
|
|
height: 50px;
|
|
float: left;
|
|
overflow: hidden;
|
|
position: relative;
|
|
background-size: 100%;
|
|
background-position: center center;
|
|
}
|
|
|
|
#news_box .news_item .news_articel_item .right-text {
|
|
float: left;
|
|
width: 250px;
|
|
padding-right: 10px;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
#news_box .news_item .hr-line-dashed:last-child {
|
|
display: none
|
|
}
|
|
|
|
#news_box .hr-line-dashed {
|
|
margin: 6px 0 1px 0
|
|
}
|
|
|
|
#news_box .news_tools {
|
|
top: 0;
|
|
z-index: 80;
|
|
color: #fff;
|
|
width: 312px;
|
|
padding: 0 5px;
|
|
margin-left: -6px;
|
|
line-height: 38px;
|
|
text-align: right;
|
|
position: absolute;
|
|
background: rgba(0, 0, 0, 0.7);
|
|
}
|
|
|
|
#news_box .news_tools a {
|
|
color: #fff;
|
|
margin-left: 10px
|
|
}
|
|
|
|
</style>
|
|
{/block} |