LiGuang 3 gadi atpakaļ
vecāks
revīzija
0b11c8b928

+ 204 - 0
src/views/system/UserPrizeList.vue

@@ -0,0 +1,204 @@
+<template>
+  <a-card :bordered="false">
+
+    <!-- 查询区域 -->
+    <div class="table-page-search-wrapper">
+      <a-form layout="inline" @keyup.enter.native="searchQuery">
+        <a-row :gutter="24">
+
+          <a-col :xl="6" :lg="7" :md="8" :sm="24">
+            <a-form-item label="员工姓名">
+              <a-input placeholder="请输入员工姓名" v-model="queryParam.userId"></a-input>
+            </a-form-item>
+          </a-col>
+          <a-col :xl="6" :lg="7" :md="8" :sm="24">
+            <a-form-item label="部门名称">
+              <a-input placeholder="请输入部门名称" v-model="queryParam.deptId"></a-input>
+            </a-form-item>
+          </a-col>
+        <template v-if="toggleSearchStatus">
+          <a-col :xl="6" :lg="7" :md="8" :sm="24">
+            <a-form-item label="类型">
+             <a-select v-model="queryParam.type" placeholder="请选择类型"
+               :getPopupContainer="(target) => target.parentNode">
+               <a-select-option value="0">奖</a-select-option>
+               <a-select-option value="1">惩</a-select-option>
+             </a-select>
+            </a-form-item>
+          </a-col>
+          <a-col :xl="6" :lg="7" :md="8" :sm="24">
+            <a-form-item label="备注">
+              <a-input placeholder="请输入备注" v-model="queryParam.demo"></a-input>
+            </a-form-item>
+          </a-col>
+          <a-col :xl="6" :lg="7" :md="8" :sm="24">
+            <a-form-item label="日期">
+             <a-date-picker valueFormat="YYYY-MM-DD HH:mm:ss" showTime format='YYYY-MM-DD' v-model="queryParam.date"/>
+            </a-form-item>
+          </a-col>
+          </template>
+          <a-col :xl="6" :lg="7" :md="8" :sm="24">
+            <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
+              <a-button type="primary" @click="searchQuery" icon="search">查询</a-button>
+              <a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button>
+              <a @click="handleToggleSearch" style="margin-left: 8px">
+                {{ toggleSearchStatus ? '收起' : '展开' }}
+                <a-icon :type="toggleSearchStatus ? 'up' : 'down'"/>
+              </a>
+            </span>
+          </a-col>
+
+        </a-row>
+      </a-form>
+    </div>
+
+    <!-- 操作按钮区域 -->
+    <div class="table-operator">
+      <a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>
+     <!-- <a-button type="primary" icon="download" @click="handleExportXls('员工奖惩')">导出</a-button>
+      <a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel">
+        <a-button type="primary" icon="import">导入</a-button>
+      </a-upload> -->
+      <a-dropdown v-if="selectedRowKeys.length > 0">
+        <a-menu slot="overlay">
+          <a-menu-item key="1" @click="batchDel"><a-icon type="delete"/>删除</a-menu-item>
+        </a-menu>
+        <a-button style="margin-left: 8px"> 批量操作 <a-icon type="down" /></a-button>
+      </a-dropdown>
+    </div>
+
+    <!-- table区域-begin -->
+    <div>
+      <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
+        <i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择 <a style="font-weight: 600">{{ selectedRowKeys.length }}</a>项
+        <a style="margin-left: 24px" @click="onClearSelected">清空</a>
+      </div>
+
+      <a-table
+        ref="table"
+        size="middle"
+        bordered
+        rowKey="id"
+        :columns="columns"
+        :dataSource="dataSource"
+        :pagination="ipagination"
+        :loading="loading"
+        class="j-table-force-nowrap"
+        :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}"
+        @change="handleTableChange">
+
+        <span slot="action" slot-scope="text, record">
+          <a @click="handleEdit(record)">编辑</a>
+
+          <a-divider type="vertical" />
+          <a-dropdown>
+            <a class="ant-dropdown-link">更多 <a-icon type="down" /></a>
+            <a-menu slot="overlay">
+              <a-menu-item>
+                <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">
+                  <a>删除</a>
+                </a-popconfirm>
+              </a-menu-item>
+            </a-menu>
+          </a-dropdown>
+        </span>
+
+      </a-table>
+    </div>
+    <!-- table区域-end -->
+
+    <!-- 表单区域 -->
+    <userPrize-modal ref="modalForm" @ok="modalFormOk"></userPrize-modal>
+  </a-card>
+</template>
+
+<script>
+  import '@/assets/less/TableExpand.less'
+  import UserPrizeModal from './modules/UserPrizeModal'
+  import { JeecgListMixin } from '@/mixins/JeecgListMixin'
+import moment from "moment"
+  export default {
+    name: "UserPrizeList",
+    mixins:[JeecgListMixin],
+    components: {
+      UserPrizeModal
+    },
+    data () {
+      return {
+        description: '员工奖惩管理页面',
+        // 表头
+        columns: [
+          {
+            title: '#',
+            dataIndex: '',
+            key:'rowIndex',
+            width:60,
+            align:"center",
+            customRender:function (t,r,index) {
+              return parseInt(index)+1;
+            }
+           },
+		   {
+            title: '员工姓名',
+            align:"center",
+            dataIndex: 'realname'
+           },
+		   {
+            title: '部门',
+            align:"center",
+            dataIndex: 'deptname'
+           },
+		   {
+            title: '类型',
+            align:"center",
+            dataIndex: 'type',
+            customRender:function(t,r,index){
+              var name="奖";
+              if(t=="1"||t==1){
+                name="惩";
+              }
+              return name;
+            }
+           },
+		   {
+            title: '备注',
+            align:"center",
+            dataIndex: 'demo'
+           },
+		   {
+            title: '日期',
+            align:"center",
+            dataIndex: 'date',
+            customRender:function(t,r,index){
+              return moment(t).format('YYYY-MM-DD');
+            }
+           },
+          {
+            title: '操作',
+            dataIndex: 'action',
+            align:"center",
+            scopedSlots: { customRender: 'action' },
+          }
+        ],
+		url: {
+          list: "/userPrize/userPrize/list",
+          delete: "/userPrize/userPrize/delete",
+          deleteBatch: "/userPrize/userPrize/deleteBatch",
+          exportXlsUrl: "userPrize/userPrize/exportXls",
+          importExcelUrl: "userPrize/userPrize/importExcel",
+       },
+    }
+  },
+  computed: {
+    importExcelUrl: function(){
+      return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`;
+    }
+  },
+    methods: {
+     
+    }
+  }
+</script>
+<style scoped>
+  @import '~@assets/less/common.less';
+</style>

+ 205 - 0
src/views/system/modules/UserPrizeModal.vue

@@ -0,0 +1,205 @@
+<template>
+  <j-modal
+    :title="title"
+    :width="800"
+    :visible="visible"
+    :confirmLoading="confirmLoading"
+    switchFullscreen
+    @ok="handleOk"
+    @cancel="handleCancel"
+    cancelText="关闭">
+    
+    <a-spin :spinning="confirmLoading">
+      <a-form :form="form">
+      
+        <a-form-item
+          :labelCol="labelCol"
+          :wrapperCol="wrapperCol"
+          label="员工姓名">
+          <a-input placeholder="请输入员工姓名" v-decorator="['realname', validatorRules.realname ]" />
+        </a-form-item>
+        <a-form-item
+          :labelCol="labelCol"
+          :wrapperCol="wrapperCol"
+          label="部门名称">
+          <a-input placeholder="请输入部门名称" v-decorator="['deptname', validatorRules.deptname ]" />
+        </a-form-item>
+        <a-form-item
+          :labelCol="labelCol"
+          :wrapperCol="wrapperCol"
+          label="类型">
+          <a-select v-decorator="[ 'type',{initialValue:'0'}]" placeholder="请选择类型"
+            :getPopupContainer="(target) => target.parentNode">
+            <a-select-option value="0">奖</a-select-option>
+            <a-select-option value="1">惩</a-select-option>
+          </a-select>
+        </a-form-item>
+        <a-form-item
+          :labelCol="labelCol"
+          :wrapperCol="wrapperCol"
+          label="日期">
+          <a-date-picker showTime format='YYYY-MM-DD' v-decorator="[ 'date', {}]" />
+        </a-form-item>
+        <a-form-item
+          :labelCol="labelCol"
+          :wrapperCol="wrapperCol"
+          label="备注">
+          <a-textarea  placeholder="请输入备注" v-decorator="['demo', {}]" />
+        </a-form-item>
+        
+		
+      </a-form>
+    </a-spin>
+  </j-modal>
+</template>
+
+<script>
+  import { httpAction,getAction } from '@/api/manage'
+  import pick from 'lodash.pick'
+  import moment from "moment"
+
+  export default {
+    name: "UserPrizeModal",
+    data () {
+      return {
+        title:"操作",
+        visible: false,
+        model: {},
+        labelCol: {
+          xs: { span: 24 },
+          sm: { span: 5 },
+        },
+        wrapperCol: {
+          xs: { span: 24 },
+          sm: { span: 16 },
+        },
+        userid:"",
+        deptid:"",
+        confirmLoading: false,
+        form: this.$form.createForm(this),
+        validatorRules:{
+        realname:{rules: [{ required: true, message: '请输入员工名称!' },{
+              validator: this.validateRealname
+            }]},
+        deptname:{rules: [{ required: true, message: '请输入部门名称!' }]},
+        type:{rules: [{ required: true, message: '请输入类型(0奖励,1惩罚)!' }]},
+        },
+        url: {
+          add: "/userPrize/userPrize/add",
+          edit: "/userPrize/userPrize/edit",
+          dept:"/sys/user/queryUsersByusername"
+        },
+      }
+    },
+    created () {
+    },
+    methods: {
+      add () {
+        this.edit({});
+      },
+      edit (record) {
+        this.form.resetFields();
+        this.model = Object.assign({}, record);
+        this.visible = true;
+        this.deptid=record.deptid;
+        this.userid=record.userid;
+        this.$nextTick(() => {
+          this.form.setFieldsValue(pick(this.model,'realname','deptname','type','demo'))
+		  //时间格式化
+          this.form.setFieldsValue({date:this.model.date?moment(this.model.date):null})
+        });
+
+      },
+     
+      close () {
+        this.$emit('close');
+        this.visible = false;
+      },
+      handleOk () {
+        const that = this;
+        // 触发表单验证
+        this.form.validateFields((err, values) => {
+          if (!err) {
+            that.confirmLoading = true;
+            let httpurl = '';
+            let method = '';
+            if(!this.model.id){
+              httpurl+=this.url.add;
+              method = 'post';
+            }else{
+              httpurl+=this.url.edit;
+               method = 'put';
+            }
+            let formData = Object.assign(this.model, values);
+            //时间格式化
+            formData.date = formData.date?formData.date.format('YYYY-MM-DD HH:mm:ss'):null;
+            formData.userId=this.userid;
+            formData.deptId=this.deptid;
+            console.log(formData)
+            httpAction(httpurl,formData,method).then((res)=>{
+              if(res.success){
+                that.$message.success(res.message);
+                that.$emit('ok');
+              }else{
+                that.$message.warning(res.message);
+              }
+            }).finally(() => {
+              that.confirmLoading = false;
+              that.close();
+            })
+
+
+
+          }
+        })
+      },
+      queryDeptName(e){
+        getAction(this.url.dept,{realname:e}).then((res)=>{
+          if(res.success){
+            if(res.result.length>0){
+              var list=res.result;
+              this.userid= list[0].id;
+              var deptids=[];
+              var deptname=[];
+              for(var i=0;i<list.length;i++){
+                deptids.push(list[i].deptid);
+                deptname.push(list[i].deptname);
+              }
+              this.deptid=deptids.join(",");
+              this.form.setFieldsValue({
+                deptname:deptname.join(",")
+              })
+            }else{
+              this.userid="";
+              this.deptid="";
+              this.form.setFieldsValue({
+                deptname:""
+              })
+            }
+          
+          
+          }
+        }).finally(() => {
+         
+        })
+      },
+      validateRealname(rule, value, callback) {
+        if (!value) {
+          callback()
+        } else {
+          this.queryDeptName(value);
+          callback()
+        }
+      },
+      handleCancel () {
+        this.close()
+      },
+
+
+    }
+  }
+</script>
+
+<style lang="less" scoped>
+
+</style>