OA项目之会议通知(查询&是否参会&反馈详情)(一)

简介: OA项目之会议通知(查询&是否参会&反馈详情)

讲解思路

  • 会议通知SQL语句分析
  • 反馈详情SQL语句分析
  • 后台代码编写
  • 前端代码编写
    效果预览



会议查询

MeetingFeedBack.java

package com.zking.oa.model;
import org.lisen.mvc.util.AutoIncrement;
import org.lisen.mvc.util.Key;
import org.lisen.mvc.util.Table;
import com.zking.oa.util.CacheUtil;
@Table("t_oa_meeting_feedback")
public class MeetiingFeedback {
  @AutoIncrement
  @Key
  private Integer id;
  private Integer meetingId;
  private int personType;
  private int personId;
  private int result;
  private String reason;
  public Integer getId() {
    return id;
  }
  public void setId(Integer id) {
    this.id = id;
  }
  public Integer getMeetingId() {
    return meetingId;
  }
  public void setMeetingId(Integer meetingId) {
    this.meetingId = meetingId;
  }
  public int getPersonType() {
    return personType;
  }
  public void setPersonType(int personType) {
    this.personType = personType;
  }
  public int getPersonId() {
    return personId;
  }
  public void setPersonId(int personId) {
    this.personId = personId;
  }
  public int getResult() {
    return result;
  }
  public void setResult(int result) {
    this.result = result;
  }
  public String getReason() {
    return reason;
  }
  public void setReason(String reason) {
    this.reason = reason;
  }
  public MeetiingFeedback(Integer id, Integer meetingId, int personType, int personId, int result, String reason) {
    super();
    this.id = id;
    this.meetingId = meetingId;
    this.personType = personType;
    this.personId = personId;
    this.result = result;
    this.reason = reason;
  }
  public MeetiingFeedback() {
    super();
    // TODO Auto-generated constructor stub
  }
  @Override
  public String toString() {
    return "MeetiingFeedback [id=" + id + ", meetingId=" + meetingId + ", personType=" + personType + ", personId="
        + personId + ", result=" + result + ", reason=" + reason + "]";
  }
  /**
   * 获取参与人员类型描述,是参与者还是列席者
   * @return
   */
  public String getMeetingJoinTypeName() {
    return CacheUtil.getMeetingJoinType(this.personId);
  }
  /**
   * 获取参与者名称
   * @return
   */
  public String getPersonName() {
    return CacheUtil.getUser(this.getPersonId()).getName();
  }
}

MeetingFeedBackDao.java

/**
   * 会议通知:查询出我(当前登陆用户)需要参与的会议及会议的反馈信息(参会、缺席以及未读)
   * @param back
   * @param pageBean
   * @return
   * @throws SQLException 
   * @throws IllegalAccessException 
   * @throws InstantiationException 
   */
@Override
  public List<MeetiingFeedback> listMeetingFeedback(MeetiingFeedback meetingFeedback, PageBean pageBean) {
    String sql = "SELECT t1.id,t1.meetingId, t1.personType, t1.personId, t1.result, t1.reason\r\n" + 
        "   FROM t_oa_meeting_feedback t1\r\n"  +
        "   WHERE 1=1 ";
    List<Object> param = new ArrayList<Object>();
    if(meetingFeedback != null && meetingFeedback.getResult()+"" != null) {
      sql += " and t1.result = ? ";
      param.add(meetingFeedback.getResult());
    }
    if(meetingFeedback != null && meetingFeedback.getMeetingId() != null) {
      sql += " and t1.meetingId = ? ";
      param.add(meetingFeedback.getMeetingId());
    }
    return DbTemplate.query(sql, param.toArray(), pageBean, MeetiingFeedback.class);
  }

MeetingFeedBackAction.java

/**
   * 查询会议相关人员的反馈信息
   * @param req
   * @param resp
   */
  public void listMeetingFeedback(HttpServletRequest req, HttpServletResponse resp) {
    try {
      PageBean pageBean = new PageBean();
      pageBean.setRequest(req);
      List<MeetiingFeedback> list = service.listMeetingFeedback(meetingFeedback, pageBean);
      CommonUtil.sendResponse(0, "会议反馈查询成功", pageBean.getTotal(), list, resp);
    } catch (Exception e) {
      e.printStackTrace();
      CommonUtil.sendResponse(0, "会议反馈查失败", resp);
    }
  }

config.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE config[
  <!ELEMENT config (action*)>
  <!ELEMENT action (forward*)>
  <!ELEMENT forward EMPTY>
  <!ATTLIST action
    path CDATA #REQUIRED
    type CDATA #REQUIRED
  >
  <!ATTLIST forward
    name CDATA #REQUIRED
    path CDATA #REQUIRED
    redirect (true|false) "false"
  >
]>
<config>
  <action type="com.zking.oa.action.UserAction" path="/userAction"> </action>
  <action type="com.zking.oa.action.PermissionAction" path="/permissionAction"> </action>
  <action type="com.zking.oa.action.MeetinginfoAction" path="/meetinginfoAction"> </action>
  <action type="com.zking.oa.action.MeetingAuditAction" path="/meetingAuditAction"> </action>
  <action type="com.zking.oa.action.meetingFeedbackAction" path="/meetingFeedbackAction"> </action>
</config>

DateUtil.java

package com.zking.oa.util;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
 * 日期帮助类
 * @author lisensir
 */
public final class DateUtil {
  private DateUtil() {}
  private static final String FORMCAT_STR = "yyyy-MM-dd HH:mm:ss";
  /**
   * 将日期格式化为yyyy-MM-dd HH:mm:ss格式的字符串
   * @param date 需要格式化的日期
   * @return
   */
  public static String format(Date date) {
    if(date == null) return "";
    SimpleDateFormat sdf  = new SimpleDateFormat(FORMCAT_STR);
    return sdf.format(date);
  }
  /**
   * 将日期格式化为yyyy-MM-dd HH:mm:ss格式的字符串
   * @param date 需要格式化的日期
   * @param format 指定的格式字符串
   * @return
   */
  public static String format(Date date, String format) {
    if(date == null) return "";
    SimpleDateFormat sdf  = new SimpleDateFormat(format);
    return sdf.format(date);
  }
  public static void main(String[] args) {
    Date date = new Date(System.currentTimeMillis());
    String s = format(date);
    System.out.println(s);
  }
}

meetingNotify.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<%@ include file="/common/head.jsp" %>
<title>会议通知</title>
<style>
.layui-inline {
  margin-top: 20px;
}
.seatPicDiv {
  height: 180px;
}
.seatPic:active {
  height: 360px;
}
.layui-layer-page .layui-layer-content {
  /* 解决送审对话框中人员选择下拉框不能完全显示问题 */
  overflow: visible;!important
}
</style>
</head>
<body>
    <!-- 查询条件 -->
  <div class="layui-inline">
    <label class="layui-form-label">标题:</label>
    <div class="layui-input-block">
      <input type="text" name="title" id="title" placeholder="会议标题" class="layui-input">
    </div>
  </div>
  <div class="layui-inline">
    <button class="layui-btn" id="queryMeetingInfo"><i class="layui-icon layui-icon-search"></i>查询</button>
  </div>
  <!-- 用户信息表格 -->
  <table class="layui-hide" id="meetingInfoTable" lay-filter="meetingInfoTable"></table>
  <!-- 使用了layui自定义语法,当会议不能送审或排座时将按钮显示为禁用状态 -->
  <script type="text/html" id="toolbar">
       <button class="layui-btn layui-btn-sm" lay-event="feeback">反馈</button>
  </script>
</body>
</html>


相关文章
|
BI 数据安全/隐私保护 UED
以产品经理的角度去讲解原型图---会议OA项目
以产品经理的角度去讲解原型图---会议OA项目
120 1
|
8月前
|
SQL 存储 JavaScript
Layui之OA会议增删改查
Layui之OA会议增删改查
74 0
|
开发框架 JavaScript 前端开发
J2EE项目部署与发布(Windows版本)->会议OA单体项目Windows部署,spa前后端分离项目Windows部署
J2EE项目部署与发布(Windows版本)->会议OA单体项目Windows部署,spa前后端分离项目Windows部署
73 0
会议OA项目-其它页面->自定义组件应用,其它界面的布局
会议OA项目-其它页面->自定义组件应用,其它界面的布局
47 0
|
容器
会议OA项目-首页->flex弹性布局,轮播图后台数据获取及组件使用(后台数据交互mockjs),首页布局
会议OA项目-首页->flex弹性布局,轮播图后台数据获取及组件使用(后台数据交互mockjs),首页布局
89 0
|
JSON 小程序 前端开发
小程序之自定义组件 结合案例(会议OA的会议/投票管理及个人中心的搭建)详解 (4)
小程序之自定义组件 结合案例(会议OA的会议/投票管理及个人中心的搭建)详解 (4)
|
JSON 小程序 前端开发
小程序之实例会议OA的首页 (3)
小程序之实例会议OA的首页 (3)
|
JavaScript 应用服务中间件 Linux
【Linux】部署单机OA项目及搭建spa前后端分离项目
【Linux】部署单机OA项目及搭建spa前后端分离项目
87 0
|
5天前
|
存储 安全 BI
怎样利用点晴免费OA办公系统提升工作效率
随着信息技术的不断发展,OA办公系统的使用率越来越高,让企业更快捷、高效地处理各类事务。点晴免费OA办公系统是一款全面优秀的办公管理系统,其强大的功能和灵活性,为办公环境带来了巨大提升。
33 10
|
3天前
|
人工智能 自然语言处理 数据挖掘
企业数字化转型的关键:如何利用OA系统实现自动化与智能决策
在数字化时代,传统办公系统已无法满足现代企业的需求。通过将RPA(机器人流程自动化)和AI(人工智能)技术与OA系统结合,企业能实现业务流程自动化、智能决策支持,大幅提升工作效率和资源配置优化,推动数字化转型。RPA可自动处理重复任务,如审批、数据同步等;AI则提供智能数据分析、预测和决策支持,两者协同作用,助力财务管理、人力资源管理、项目管理和客户服务等多个领域实现智能化升级。未来,智能化OA系统将进一步提升个性化服务、数据安全和协作能力,成为企业发展的关键驱动力。