Преглед на файлове

教师管理,学员管理

贾小兵 преди 4 месеца
родител
ревизия
9a38ef4515

+ 2 - 2
application/admin/controller/Teacher.php → application/admin/controller/teacher/Info.php

@@ -1,6 +1,6 @@
 <?php
 
-namespace app\admin\controller;
+namespace app\admin\controller\teacher;
 
 use app\admin\model\AuthGroup;
 use app\admin\model\AuthGroupAccess;
@@ -16,7 +16,7 @@ use think\Validate;
  * @icon   fa fa-users
  * @remark 一个管理员可以有多个角色组,左侧的菜单根据管理员所拥有的权限进行生成
  */
-class Teacher extends Backend
+class Info extends Backend
 {
 
     /**

+ 37 - 0
application/admin/controller/teacher/Task.php

@@ -0,0 +1,37 @@
+<?php
+
+namespace app\admin\controller\teacher;
+
+use app\common\controller\Backend;
+
+/**
+ * sim-任务管理
+ *
+ * @icon fa fa-circle-o
+ */
+class Task extends Backend
+{
+
+    /**
+     * Task模型对象
+     * @var \app\admin\model\teacher\Task
+     */
+    protected $model = null;
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = new \app\admin\model\teacher\Task;
+
+    }
+
+
+
+    /**
+     * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
+     * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
+     * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
+     */
+
+
+}

+ 0 - 0
application/admin/lang/zh-cn/teacher.php → application/admin/lang/zh-cn/teacher/info.php


+ 14 - 0
application/admin/lang/zh-cn/teacher/task.php

@@ -0,0 +1,14 @@
+<?php
+
+return [
+    'Task_id'           => '编号',
+    'Sim_type'          => '模拟器类型',
+    'Task_type'         => '任务类型',
+    'Name'              => '任务名称',
+    'Create_by_user_id' => '创建教师',
+    'Create_by'         => '创建者',
+    'Create_time'       => '创建时间',
+    'Update_by'         => '更新者',
+    'Update_time'       => '更新时间',
+    'Remark'            => '备注'
+];

+ 3 - 0
application/admin/model/Admin.php

@@ -4,15 +4,18 @@ namespace app\admin\model;
 
 use think\Model;
 use think\Session;
+use traits\model\SoftDelete;
 
 class Admin extends Model
 {
+    use SoftDelete;
 
     // 开启自动写入时间戳字段
     protected $autoWriteTimestamp = 'int';
     // 定义时间戳字段名
     protected $createTime = 'createtime';
     protected $updateTime = 'updatetime';
+    protected $deleteTime = 'deletetime';
     protected $hidden = [
         'password',
         'salt'

+ 40 - 0
application/admin/model/teacher/Task.php

@@ -0,0 +1,40 @@
+<?php
+
+namespace app\admin\model\teacher;
+
+use think\Model;
+
+
+class Task extends Model
+{
+
+    
+
+    
+
+    // 表名
+    protected $name = 'sim_task';
+    
+    // 自动写入时间戳字段
+    protected $autoWriteTimestamp = false;
+
+    // 定义时间戳字段名
+    protected $createTime = false;
+    protected $updateTime = false;
+    protected $deleteTime = false;
+
+    // 追加属性
+    protected $append = [
+
+    ];
+    
+
+    
+
+
+
+
+
+
+
+}

+ 27 - 0
application/admin/validate/teacher/Task.php

@@ -0,0 +1,27 @@
+<?php
+
+namespace app\admin\validate\teacher;
+
+use think\Validate;
+
+class Task extends Validate
+{
+    /**
+     * 验证规则
+     */
+    protected $rule = [
+    ];
+    /**
+     * 提示消息
+     */
+    protected $message = [
+    ];
+    /**
+     * 验证场景
+     */
+    protected $scene = [
+        'add'  => [],
+        'edit' => [],
+    ];
+    
+}

+ 1 - 1
application/admin/view/department/index/index.html

@@ -10,7 +10,7 @@
                 <div class="widget-body no-padding">
                     <div id="toolbar" class="toolbar">
                         {:build_toolbar('refresh,add,edit,del')}
-
+                        <a href="javascript:;" class="btn btn-danger btn-toggle-all"><i class="fa fa-plus"></i> {:__('显示全部')}</a>
 
 
                     </div>

+ 30 - 30
application/admin/view/general/profile/index.html

@@ -62,14 +62,14 @@
                             <label for="username" class="control-label">{:__('Username')}:</label>
                             <input type="text" class="form-control" id="username" name="row[username]" value="{$admin.username|htmlentities}" disabled/>
                         </div>
-                        <div class="form-group">
-                            <label for="mobile" class="control-label">{:__('Mobile')}:</label>
-                            <input type="text" class="form-control" id="mobile" name="row[mobile]" value="{$admin.mobile|htmlentities}" disabled/>
-                        </div>
-                        <div class="form-group">
-                            <label for="email" class="control-label">{:__('Email')}:</label>
-                            <input type="text" class="form-control" id="email" name="row[email]" value="{$admin.email|htmlentities}" data-rule="required;email"/>
-                        </div>
+<!--                        <div class="form-group">-->
+<!--                            <label for="mobile" class="control-label">{:__('Mobile')}:</label>-->
+<!--                            <input type="text" class="form-control" id="mobile" name="row[mobile]" value="{$admin.mobile|htmlentities}" disabled/>-->
+<!--                        </div>-->
+<!--                        <div class="form-group">-->
+<!--                            <label for="email" class="control-label">{:__('Email')}:</label>-->
+<!--                            <input type="text" class="form-control" id="email" name="row[email]" value="{$admin.email|htmlentities}" data-rule="required;email"/>-->
+<!--                        </div>-->
                         <div class="form-group">
                             <label for="nickname" class="control-label">{:__('Nickname')}:</label>
                             <input type="text" class="form-control" id="nickname" name="row[nickname]" value="{$admin.nickname|htmlentities}" data-rule="required"/>
@@ -89,30 +89,30 @@
         </div>
 
     </div>
-    <div class="col-md-8">
-        <div class="panel panel-default panel-intro panel-nav">
-            <div class="panel-heading">
-                <ul class="nav nav-tabs">
-                    <li class="active"><a href="#one" data-toggle="tab"><i class="fa fa-list"></i> {:__('Admin log')}</a></li>
-                </ul>
-            </div>
-            <div class="panel-body">
-                <div id="myTabContent" class="tab-content">
-                    <div class="tab-pane fade active in" id="one">
-                        <div class="widget-body no-padding">
-                            <div id="toolbar" class="toolbar">
-                                {:build_toolbar('refresh')}
-                            </div>
-                            <table id="table" class="table table-striped table-bordered table-hover table-nowrap" width="100%">
+<!--    <div class="col-md-8">-->
+<!--        <div class="panel panel-default panel-intro panel-nav">-->
+<!--            <div class="panel-heading">-->
+<!--                <ul class="nav nav-tabs">-->
+<!--                    <li class="active"><a href="#one" data-toggle="tab"><i class="fa fa-list"></i> {:__('Admin log')}</a></li>-->
+<!--                </ul>-->
+<!--            </div>-->
+<!--            <div class="panel-body">-->
+<!--                <div id="myTabContent" class="tab-content">-->
+<!--                    <div class="tab-pane fade active in" id="one">-->
+<!--                        <div class="widget-body no-padding">-->
+<!--                            <div id="toolbar" class="toolbar">-->
+<!--                                {:build_toolbar('refresh')}-->
+<!--                            </div>-->
+<!--                            <table id="table" class="table table-striped table-bordered table-hover table-nowrap" width="100%">-->
 
-                            </table>
+<!--                            </table>-->
 
-                        </div>
-                    </div>
+<!--                        </div>-->
+<!--                    </div>-->
 
-                </div>
-            </div>
-        </div>
+<!--                </div>-->
+<!--            </div>-->
+<!--        </div>-->
 
-    </div>
+<!--    </div>-->
 </div>

+ 91 - 117
application/admin/view/index/login.html

@@ -1,146 +1,120 @@
 <!DOCTYPE html>
-<html>
+<html lang="{$config.language}">
 <head>
     {include file="common/meta" /}
-
-    <style type="text/css">
-        body {
-            color: #999;
-            background-color: #f1f4fd;
-            background-size: cover;
-        }
-
-        a {
-            color: #444;
+    <style>
+        body{
+            background-image: url(/assets/img/login-background.jpg);
+            background-size: 100%;
         }
-
-
-        .login-screen {
-            max-width: 430px;
-            padding: 0;
-            margin: 100px auto 0 auto;
-
+        .container {
+            background-color: #ffffff;
+            width: 400px;
+            margin: auto!important;
+            padding: 30px 10px!important;
+            position: absolute;
+            right: 25%!important;
+            top: 50%;
+            transform: translate(50%, -50%);
+            border-radius: 5px;
+            box-shadow: 0px 0px 16px #7b7a7a;
+            border-radius: 5px;
         }
-
-        .login-screen .well {
-            border-radius: 3px;
-            -webkit-box-shadow: 0 0 30px rgba(0, 0, 0, 0.1);
-            box-shadow: 0 0 30px rgba(0, 0, 0, 0.1);
-            background: rgba(255, 255, 255, 1);
-            border: none;
-            /*overflow: hidden;*/
-            padding: 0;
-        }
-
-        @media (max-width: 767px) {
-            .login-screen {
-                padding: 0 20px;
-            }
-        }
-
-        .profile-img-card {
-            width: 100px;
-            height: 100px;
-            display: block;
-            -moz-border-radius: 50%;
-            -webkit-border-radius: 50%;
-            border-radius: 50%;
-            margin: -93px auto 30px;
-            border: 5px solid #fff;
-        }
-
-        .profile-name-card {
+        .logon-tab {
             text-align: center;
+            font-size: 16px;
+            font-weight: 600;
         }
-
-        .login-head {
-            background: #899fe1;
-            border-radius: 3px 3px 0 0;
+        .logon-tab a:hover {
+            color: #000;
+            text-decoration: none;
+            cursor: default;
         }
-
-        .login-form {
-            padding: 40px 30px;
-            position: relative;
-            z-index: 99;
+        input[type = text]{
+            height: 42px;
+            border-color: #ebedf2;
+            padding-left: 35px;
         }
-
-        #login-form {
-            margin-top: 20px;
+        input[type = password]{
+            padding-left: 35px;
         }
-
-        #login-form .input-group {
-            margin-bottom: 15px;
+        .glyphicon-user{
+            top: 32px;
+            left: 15px;
+            color: #b1b1b1;
         }
-
-        #login-form .form-control {
-            font-size: 13px;
+        .glyphicon-lock{
+            top: 32px;
+            left: 15px;
+            color: #b1b1b1;
         }
-
+        button[type=submit] {
+            height: 35px;
+            color: white;
+            border-radius: 30px;
+        }
+        .msg-box{width: 100%;position: inherit}
     </style>
     <!--@formatter:off-->
     {if $background}
-        <style type="text/css">
-            body{
-                background-image: url('{$background}');
-            }
-        </style>
+    <style type="text/css">
+        body{
+            background-image: url('{$background}');
+        }
+    </style>
     {/if}
     <!--@formatter:on-->
 </head>
 <body>
-<div class="container">
-    <div class="login-wrapper">
-        <div class="login-screen">
-            <div class="well">
-                <div class="login-head">
-                    <img src="__CDN__/assets/img/login-head.png" style="width:100%;"/>
+<div id="content-container" class="container">
+    <div class="user-section login-section">
+        <div class="logon-tab clearfix"> <a class="active" style="color: #2c3e50">{:__('Sign in')}</a> </div>
+        <div class="login-main">
+            <form name="form" id="login-form" class="form-vertical" method="POST" action="">
+                {:token()}
+                <div class="form-group">
+                    <div class="controls">
+                        <span class="glyphicon glyphicon-user"></span>
+                        <input class="form-control input-lg" id="username" type="text" name="username" value="" data-rule="{:__('Username')}:required" placeholder="{:__('Username')}" autocomplete="off">
+                        <div class="help-block"></div>
+
+                    </div>
                 </div>
-                <div class="login-form">
-                    <img id="profile-img" class="profile-img-card" src="__CDN__/assets/img/avatar.png"/>
-                    <p id="profile-name" class="profile-name-card"></p>
+                <div class="form-group">
+                    <!-- <label class="control-label" for="password">{:__('Password')}:</label> -->
+                    <div class="controls">
+                        <span class="glyphicon glyphicon-lock"></span>
+                        <input class="form-control input-lg" id="password" type="password" name="password" value="" data-rule="{:__('Password')}:required;password" placeholder="{:__('Password')}" autocomplete="off">
 
-                    <form action="" method="post" id="login-form">
-                        <!--@AdminLoginFormBegin-->
-                        <div id="errtips" class="hide"></div>
-                        {:token()}
-                        <div class="input-group">
-                            <div class="input-group-addon"><span class="glyphicon glyphicon-user" aria-hidden="true"></span></div>
-                            <input type="text" class="form-control" id="pd-form-username" placeholder="{:__('Username')}" name="username" autocomplete="off" value="" data-rule="{:__('Username')}:required;username"/>
-                        </div>
+                        <div class="help-block"></div>
+
+                    </div>
+                </div>
 
-                        <div class="input-group">
-                            <div class="input-group-addon"><span class="glyphicon glyphicon-lock" aria-hidden="true"></span></div>
-                            <input type="password" class="form-control" id="pd-form-password" placeholder="{:__('Password')}" name="password" autocomplete="off" value="" data-rule="{:__('Password')}:required;password"/>
-                        </div>
-                        <!--@CaptchaBegin-->
-                        {if $Think.config.fastadmin.login_captcha}
-                        <div class="input-group">
-                            <div class="input-group-addon"><span class="glyphicon glyphicon-option-horizontal" aria-hidden="true"></span></div>
-                            <input type="text" name="captcha" class="form-control" placeholder="{:__('Captcha')}" data-rule="{:__('Captcha')}:required;length({$Think.config.captcha.length})" autocomplete="off"/>
-                            <span class="input-group-addon" style="padding:0;border:none;cursor:pointer;">
-                                    <img src="{:rtrim('__PUBLIC__', '/')}/index.php?s=/captcha" width="100" height="30" onclick="this.src = '{:rtrim('__PUBLIC__', '/')}/index.php?s=/captcha&r=' + Math.random();"/>
+                {if $Think.config.fastadmin.login_captcha}
+                <div class="input-group" style="margin-top: 32px;">
+                    <div class="input-group-addon"><span class="glyphicon glyphicon-option-horizontal" aria-hidden="true"></span></div>
+                    <input type="text" style="padding-left: 2px;font-size: 16px;" name="captcha" class="form-control" placeholder="{:__('Captcha')}" data-rule="{:__('Captcha')}:required;length(4)"/>
+                    <span class="input-group-addon" style="padding:0;border:none;cursor:pointer;">
+                                <img src="{:rtrim('__PUBLIC__', '/')}/index.php?s=/captcha" width="100" height="30" onclick="this.src = '{:rtrim('__PUBLIC__', '/')}/index.php?s=/captcha&r=' + Math.random();"/>
                             </span>
-                        </div>
-                        {/if}
-                        <!--@CaptchaEnd-->
-                        {if $keeyloginhours>0}
-                        <div class="form-group checkbox">
-                            <label class="inline" for="keeplogin" data-toggle="tooltip" title="{:__('The duration of the session is %s hours', $keeyloginhours)}">
-                                <input type="checkbox" name="keeplogin" id="keeplogin" value="1"/>
-                                {:__('Keep login')}
-                            </label>
-                        </div>
-                        {/if}
-                        <div class="form-group">
-                            <button type="submit" class="btn btn-success btn-lg btn-block" style="background:#708eea;">{:__('Sign in')}</button>
-                        </div>
-                        <!--@AdminLoginFormEnd-->
-                    </form>
+                    <div class="help-block"></div>
+                </div>
+                {/if}
+
+                <div class="input-group" style="margin: 28px 0px;">
+                    <div class="controls">
+                        <input type="checkbox" name="keeplogin" checked="checked" value="1"> {:__('Keep login')}
+                        <!-- <div class="pull-ri                      ght"><a href="javascript:;" class="btn-forgot">{:__('Forgot password')}</a></div> -->
+                    </div>
+                </div>
+                <div class="form-group">
+                    <button type="submit" style="color: #white;background: #177dff;border-color: #177dff;padding: .20rem .5rem;font-size: 1rem" class="btn btn-primary btn-lg btn-block">{:__('Sign in')}</button>
                 </div>
-            </div>
+            </form>
         </div>
     </div>
 </div>
 {include file="common/script" /}
 </body>
-</html>
+</html>

+ 0 - 0
application/admin/view/teacher/add.html → application/admin/view/teacher/info/add.html


+ 0 - 0
application/admin/view/teacher/edit.html → application/admin/view/teacher/info/edit.html


+ 0 - 0
application/admin/view/teacher/index.html → application/admin/view/teacher/info/index.html


+ 63 - 0
application/admin/view/teacher/task/add.html

@@ -0,0 +1,63 @@
+<form id="add-form" class="form-horizontal" role="form" data-toggle="validator" method="POST" action="">
+
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Sim_type')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-sim_type" data-rule="required" class="form-control" name="row[sim_type]" type="text">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Task_type')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-task_type" data-rule="required" class="form-control" name="row[task_type]" type="text">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Name')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-name" data-rule="required" class="form-control" name="row[name]" type="text" value="">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Create_by_user_id')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-create_by_user_id" data-rule="required" data-source="create/by/user/index" class="form-control selectpage" name="row[create_by_user_id]" type="text" value="">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Create_by')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-create_by" class="form-control" name="row[create_by]" type="text">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Create_time')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-create_time" class="form-control datetimepicker" data-date-format="YYYY-MM-DD HH:mm:ss" data-use-current="true" name="row[create_time]" type="text" value="{:date('Y-m-d H:i:s')}">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Update_by')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-update_by" class="form-control" name="row[update_by]" type="text">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Update_time')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-update_time" class="form-control datetimepicker" data-date-format="YYYY-MM-DD HH:mm:ss" data-use-current="true" name="row[update_time]" type="text" value="{:date('Y-m-d H:i:s')}">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Remark')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-remark" class="form-control" name="row[remark]" type="text">
+        </div>
+    </div>
+    <div class="form-group layer-footer">
+        <label class="control-label col-xs-12 col-sm-2"></label>
+        <div class="col-xs-12 col-sm-8">
+            <button type="submit" class="btn btn-primary btn-embossed disabled">{:__('OK')}</button>
+        </div>
+    </div>
+</form>

+ 63 - 0
application/admin/view/teacher/task/edit.html

@@ -0,0 +1,63 @@
+<form id="edit-form" class="form-horizontal" role="form" data-toggle="validator" method="POST" action="">
+
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Sim_type')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-sim_type" data-rule="required" class="form-control" name="row[sim_type]" type="text" value="{$row.sim_type|htmlentities}">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Task_type')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-task_type" data-rule="required" class="form-control" name="row[task_type]" type="text" value="{$row.task_type|htmlentities}">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Name')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-name" data-rule="required" class="form-control" name="row[name]" type="text" value="{$row.name|htmlentities}">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Create_by_user_id')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-create_by_user_id" data-rule="required" data-source="create/by/user/index" class="form-control selectpage" name="row[create_by_user_id]" type="text" value="{$row.create_by_user_id|htmlentities}">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Create_by')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-create_by" class="form-control" name="row[create_by]" type="text" value="{$row.create_by|htmlentities}">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Create_time')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-create_time" class="form-control datetimepicker" data-date-format="YYYY-MM-DD HH:mm:ss" data-use-current="true" name="row[create_time]" type="text" value="{$row.create_time}">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Update_by')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-update_by" class="form-control" name="row[update_by]" type="text" value="{$row.update_by|htmlentities}">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Update_time')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-update_time" class="form-control datetimepicker" data-date-format="YYYY-MM-DD HH:mm:ss" data-use-current="true" name="row[update_time]" type="text" value="{$row.update_time}">
+        </div>
+    </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Remark')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-remark" class="form-control" name="row[remark]" type="text" value="{$row.remark|htmlentities}">
+        </div>
+    </div>
+    <div class="form-group layer-footer">
+        <label class="control-label col-xs-12 col-sm-2"></label>
+        <div class="col-xs-12 col-sm-8">
+            <button type="submit" class="btn btn-primary btn-embossed disabled">{:__('OK')}</button>
+        </div>
+    </div>
+</form>

+ 29 - 0
application/admin/view/teacher/task/index.html

@@ -0,0 +1,29 @@
+<div class="panel panel-default panel-intro">
+    {:build_heading()}
+
+    <div class="panel-body">
+        <div id="myTabContent" class="tab-content">
+            <div class="tab-pane fade active in" id="one">
+                <div class="widget-body no-padding">
+                    <div id="toolbar" class="toolbar">
+                        <a href="javascript:;" class="btn btn-primary btn-refresh" title="{:__('Refresh')}" ><i class="fa fa-refresh"></i> </a>
+                        <a href="javascript:;" class="btn btn-success btn-add {:$auth->check('teacher.task/add')?'':'hide'}" title="{:__('Add')}" ><i class="fa fa-plus"></i> {:__('Add')}</a>
+                        <a href="javascript:;" class="btn btn-success btn-edit btn-disabled disabled {:$auth->check('teacher.task/edit')?'':'hide'}" title="{:__('Edit')}" ><i class="fa fa-pencil"></i> {:__('Edit')}</a>
+                        <a href="javascript:;" class="btn btn-danger btn-del btn-disabled disabled {:$auth->check('teacher.task/del')?'':'hide'}" title="{:__('Delete')}" ><i class="fa fa-trash"></i> {:__('Delete')}</a>
+                        
+
+                        
+
+                        
+                    </div>
+                    <table id="table" class="table table-striped table-bordered table-hover table-nowrap"
+                           data-operate-edit="{:$auth->check('teacher.task/edit')}"
+                           data-operate-del="{:$auth->check('teacher.task/del')}"
+                           width="100%">
+                    </table>
+                </div>
+            </div>
+
+        </div>
+    </div>
+</div>

+ 4 - 0
application/extra/site.php

@@ -41,4 +41,8 @@ return array (
     'category2' => 'Category2',
     'custom' => 'Custom',
   ),
+  'sim_sim_type' => '',
+  'sim_question_setting_method' => '',
+  'sim_sim_state' => '',
+  'sim_repair' => '',
 );

BIN
public/assets/img/login-background.jpg


+ 5 - 4
public/assets/js/backend/teacher.js → public/assets/js/backend/teacher/info.js

@@ -5,10 +5,10 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin
             // 初始化表格参数配置
             Table.api.init({
                 extend: {
-                    index_url: 'teacher/index',
-                    add_url: 'teacher/add',
-                    edit_url: 'teacher/edit',
-                    del_url: 'teacher/del',
+                    index_url: 'teacher/info/index',
+                    add_url: 'teacher/info/add',
+                    edit_url: 'teacher/info/edit',
+                    del_url: 'teacher/info/del',
                     // multi_url: 'auth/admin/multi',
                 }
             });
@@ -27,6 +27,7 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin
             // 初始化表格
             table.bootstrapTable({
                 url: $.fn.bootstrapTable.defaults.extend.index_url,
+                searchFormVisible:true,
                 columns: [
                     [
                         {field: 'state', checkbox: true, },

+ 63 - 0
public/assets/js/backend/teacher/task.js

@@ -0,0 +1,63 @@
+define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {
+
+    var Controller = {
+        index: function () {
+            // 初始化表格参数配置
+            Table.api.init({
+                extend: {
+                    index_url: 'teacher.task/index' + location.search,
+                    add_url: 'teacher.task/add',
+                    edit_url: 'teacher.task/edit',
+                    del_url: 'teacher.task/del',
+                    multi_url: 'teacher.task/multi',
+                    import_url: 'teacher.task/import',
+                    table: 'teacher_task',
+                }
+            });
+
+            var table = $("#table");
+
+            // 初始化表格
+            table.bootstrapTable({
+                url: $.fn.bootstrapTable.defaults.extend.index_url,
+                pk: 'task_id',
+                sortName: 'task_id',
+                fixedColumns: true,
+                fixedRightNumber: 1,
+                columns: [
+                    [
+                        {checkbox: true},
+                        {field: 'task_id', title: __('Task_id')},
+                        {field: 'sim_type', title: __('Sim_type')},
+                        {field: 'task_type', title: __('Task_type')},
+                        {field: 'name', title: __('Name'), operate: 'LIKE', table: table, class: 'autocontent', formatter: Table.api.formatter.content},
+                        // {field: 'create_by_user_id', title: __('Create_by_user_id')},
+                        {field: '', title: __('故障现象数量')},
+                        {field: '', title: __('故障部位数量')},
+                        {field: 'create_by', title: __('Create_by'), operate: 'LIKE'},
+                        {field: 'createtime', title: __('Create_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
+                        // {field: 'update_by', title: __('Update_by'), operate: 'LIKE'},
+                        // {field: 'update_time', title: __('Update_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
+                        {field: 'remark', title: __('Remark'), operate: false, table: table, class: 'autocontent'},
+                        {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
+                    ]
+                ]
+            });
+
+            // 为表格绑定事件
+            Table.api.bindevent(table);
+        },
+        add: function () {
+            Controller.api.bindevent();
+        },
+        edit: function () {
+            Controller.api.bindevent();
+        },
+        api: {
+            bindevent: function () {
+                Form.api.bindevent($("form[role=form]"));
+            }
+        }
+    };
+    return Controller;
+});

+ 3 - 0
public/img.html

@@ -0,0 +1,3 @@
+<script>
+window.location.href="/ZQOtIMLKud.php/index/login"
+</script>