当前位置:首页 > 影视资讯 > 苹果CMS 批量设置视频更新

苹果CMS 批量设置视频更新

5个月前 (12-16)影视资讯208

在后台视频数据管理页面增加一个更新时间按钮,可以批量设置视频的更新时间,某些情况下还是挺好用的,一共涉及两处修改:

1、application/admin/controller/Vod.php

查找 public function field() 在这个函数上方新增

    public function updateTimeBatch()
    {
        $param = input();
        $ids = isset($param['ids']) ? $param['ids'] : '';
        $time = isset($param['time']) ? trim($param['time']) : '';

        if (empty($ids)) {
            return $this->error(lang('param_err'));
        }

        $timestamp = time();
        if (!empty($time)) {
            $tmp = strtotime($time);
            if ($tmp !== false) {
                $timestamp = $tmp;
            }
        }

        $where['vod_id'] = ['in', $ids];
        $update = ['vod_time' => $timestamp];
        $res = model('Vod')->fieldData($where, $update);
        if ($res['code'] > 1) {
            return $this->error($res['msg']);
        }
        return $this->success($res['msg']);
    }

2、application/admin/view/vod/index.html

查找

<a class="layui-btn layui-btn-primary j-iframe" data-checkbox="true" data-href="{:url('make/make?ac=info&tab=vod')}" href="javascript:;" title="{:lang('make_page')}"><i class="layui-icon">&#xe620;</i>{:lang('make_page')}</a>

在这段代码下方新增:

<a class="layui-btn layui-btn-primary" id="btnBatchUpdateTime" href="javascript:;" title="{:lang('update_time')}"><i class="layui-icon">&#xe637;</i>{:lang('update_time')}</a>


找到页面底部的js脚本里的
layui.use(['laypage', 'layer','form'], function() {
改为
layui.use(['laypage', 'layer','form','laydate'], function() {


找到
form = layui.form;
改为
form = layui.form,
laydate = layui.laydate;


找到
// 小屏幕下名称问题
if ($('body').width() <= 600) {
$('#table_th_vod_name').attr('width', '300');
}
在下方新增

$('#btnBatchUpdateTime').on('click', function () {
            var ids = [];
            $('.checkbox-ids:checked').each(function (index, item) {
                if (item.checked) {
                    ids.push(item.value);
                }
            });
            if (ids.length < 1) {
                layer.msg('{:lang('请先选择视频')}');
                return false;
            }

            var content = '<div style="padding:15px 20px 0 20px;">' +
                '<input type="text" class="layui-input" id="batchUpdateTimeInput" placeholder="{:lang('update_time')}">' +
                '<p style="margin-top:8px;color:#999;">{:lang('批量设置视频')} {:lang('update_time')}</p>' +
                '</div>';

            var openIndex = layer.open({
                type: 1,
                title: '{:lang('update_time')}',
                area: ['360px', '200px'],
                content: content,
                btn: ['{:lang('确定')}','{:lang('取消')}'],
                success: function () {
                    laydate.render({
                        elem: '#batchUpdateTimeInput',
                        type: 'datetime',
                        value: new Date()
                    });
                },
                yes: function () {
                    var timeVal = $('#batchUpdateTimeInput').val();
                    layer.msg('{:lang('wait_submit')}', {time: 500000});
                    $.post("{:url('updateTimeBatch')}", {ids: ids.join(','), time: timeVal}, function (res) {
                        layer.msg(res.msg, {}, function () {
                            if (res.code == 1) {
                                location.reload();
                            }
                        });
                    });
                    layer.close(openIndex);
                }
            });
        });

完整的js脚本代码为:

<script type="text/javascript">
    var curUrl="{:url('vod/data',$param)}";
    layui.use(['laypage', 'layer','form','laydate'], function() {
        var laypage = layui.laypage
                , layer = layui.layer,
                form = layui.form,
                laydate = layui.laydate;
                $ = layui.jquery;

        laypage.render({
            elem: 'pages'
            ,count: {$total}
            ,limit: {$limit}
            ,curr: {$page}
            ,layout: ['count', 'prev', 'page', 'next', 'limit', 'skip']
            ,jump: function(obj,first){
                if(!first){
                    location.href = curUrl.replace('%7Bpage%7D',obj.curr).replace('%7Blimit%7D',obj.limit);
                }
            }
        });

        // 小屏幕下名称问题
        if ($('body').width() <= 600) {
            $('#table_th_vod_name').attr('width', '300');
        }

        $('#btnBatchUpdateTime').on('click', function () {
            var ids = [];
            $('.checkbox-ids:checked').each(function (index, item) {
                if (item.checked) {
                    ids.push(item.value);
                }
            });
            if (ids.length < 1) {
                layer.msg('{:lang('请先选择视频')}');
                return false;
            }

            var content = '<div style="padding:15px 20px 0 20px;">' +
                '<input type="text" class="layui-input" id="batchUpdateTimeInput" placeholder="{:lang('update_time')}">' +
                '<p style="margin-top:8px;color:#999;">{:lang('批量设置视频')} {:lang('update_time')}</p>' +
                '</div>';

            var openIndex = layer.open({
                type: 1,
                title: '{:lang('update_time')}',
                area: ['360px', '200px'],
                content: content,
                btn: ['{:lang('确定')}','{:lang('取消')}'],
                success: function () {
                    laydate.render({
                        elem: '#batchUpdateTimeInput',
                        type: 'datetime',
                        value: new Date()
                    });
                },
                yes: function () {
                    var timeVal = $('#batchUpdateTimeInput').val();
                    layer.msg('{:lang('wait_submit')}', {time: 500000});
                    $.post("{:url('updateTimeBatch')}", {ids: ids.join(','), time: timeVal}, function (res) {
                        layer.msg(res.msg, {}, function () {
                            if (res.code == 1) {
                                location.reload();
                            }
                        });
                    });
                    layer.close(openIndex);
                }
            });
        });

    });
</script>


扫描二维码推送至手机访问。

版权声明:本文由沁馨影视网发布,如需转载请注明出处。

本文链接:https://qxys.qxnnn.com/yszx/542.html

分享给朋友:

相关文章

被折叠的时空与人性悖

被折叠的时空与人性悖

《量子回声》以一场实验室量子纠缠事故为起点,构建了三个时空维度交错的叙事框架。导演通过冷色调的视觉语言与碎片化剪辑,将科学概念转化为极具沉浸感的哲学寓言。影片最惊艳的设计在于"回声效应"——每个角色的选择都会在平行时空产生涟漪,最终在第四幕形成环状叙事闭环。这种结构不仅挑战观众认...

《冰山上的来客》具有深刻的历史与艺术价值!

《冰山上的来客》具有深刻的历史与艺术价值!

一、冰峰之上的双重叙事:个人命运与集体信仰的交织影片通过阿米尔与古兰丹姆的爱情悲剧,构建起"个体记忆-国家叙事"的双重线索。童年分别时《花儿为什么这样红》的歌声,既是青春恋曲的绝唱,也成为贯穿全片的身份密码。特务假扮古兰丹姆的设定,巧妙将私人情感转化为政治隐喻——当阿米尔在婚礼上...

《南京照相馆》历史厚重感与人性的光辉!

《南京照相馆》历史厚重感与人性的光辉!

一、历史洪流中的个体叙事影片以1937年南京城一家照相馆为叙事中心,通过掌柜陈默(张译饰)为不同阶层人物拍照的视角,展现战争前夕的市井百态。导演采用"照相馆"这一封闭空间作为历史显微镜,既规避了宏大叙事的说教感,又通过相片这一载体实现了"瞬间即永恒"的艺术表达...

《寄生虫》的阶级隐喻

《寄生虫》的阶级隐喻

一、引言:一座房子的两种人生奉俊昊用半地下室的霉味与豪宅的香氛,在2019年撕开了全球中产社会的华丽帷幕。《寄生虫》通过金基泽一家与朴社长一家的命运交织,将韩国社会的阶级固化转化为具象的空间对抗。影片中垂直分布的住宅空间,既是物理层面的建筑分层,更是社会阶层的残酷映射。二、空间叙事中的阶级符号学半地...

当引力波遇见父女情:《星际穿越》的科学浪漫主义

当引力波遇见父女情:《星际穿越》的科学浪漫主义

在库珀穿越虫洞的瞬间,观众跟随IMAX镜头经历了从牛顿力学到量子力学的认知跃迁。诺兰用严谨的物理公式编织的这则太空史诗,其伟大之处在于将相对论和弦理论转化为触手可及的情感语言——当墨菲在五维书架前颤抖着喊出爸爸时,引力透镜效应与人类心跳产生了奇妙的共振。一、时间褶皱中的相对论诗学影片对爱因斯坦理论的...

汉斯·季默与朋友们:沙漠之钻

汉斯·季默与朋友们:沙漠之钻

一、叙事迷宫:双线交织的宿命轮回导演以钻石走私案为叙事明线,嵌套阿拉伯传说《一千零一夜》的叙事框架。现代线中,珠宝鉴定师艾琳在迪拜追查血钻来源时,其随身携带的祖母绿项链成为关键物证;古代线里,沙漠商队首领阿卜杜拉为解救被囚禁的公主,用同一颗宝石编织谎言。两条时空线通过宝石的流转形成闭环,当现代艾琳发...