OOMeetingInforController.swift 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. //
  2. // OOMeetingInforController.swift
  3. // o2app
  4. //
  5. // Created by 刘振兴 on 2018/1/4.
  6. // Copyright © 2018年 zone. All rights reserved.
  7. //
  8. import UIKit
  9. import EmptyDataSet_Swift
  10. import Promises
  11. import CocoaLumberjack
  12. private let meetingIdentifier = "OOMeetingInforItemCell"
  13. class OOMeetingInforController: UIViewController {
  14. @IBOutlet weak var tableView: UITableView!
  15. private var sectionHeight = CGFloat(172.0)
  16. private var hSectionHeight = CGFloat(387.0)
  17. private var sFlag = false
  18. private var config: OOMeetingConfigInfo? = nil
  19. //指定日期的所有会议
  20. private var theMeetingsByDay: [OOMeetingInfo] = []
  21. private lazy var viewModel: OOMeetingMainViewModel = {
  22. return OOMeetingMainViewModel()
  23. }()
  24. private var headerView: OOMeetingInforHeaderView = {
  25. let view = Bundle.main.loadNibNamed("OOMeetingInforHeaderView", owner: self, options: nil)?.first as! OOMeetingInforHeaderView
  26. return view
  27. }()
  28. private lazy var createView: O2BBSCreatorView = {
  29. let view = Bundle.main.loadNibNamed("O2BBSCreatorView", owner: self, options: nil)?.first as! O2BBSCreatorView
  30. view.iconImage = #imageLiteral(resourceName: "icon_collection_pencil")
  31. view.delegate = self
  32. view.frame = CGRect(x: kScreenW - 50 - 25, y: kScreenH - 50 - 25 - 40, width: 50, height: 50)
  33. return view
  34. }()
  35. override func viewDidLoad() {
  36. super.viewDidLoad()
  37. self.tabBarItem?.selectedImage = O2ThemeManager.image(for: "Icon.icon_huiyi_pro")
  38. tableView.register(UINib.init(nibName: "OOMeetingInforItemCell", bundle: nil), forCellReuseIdentifier: meetingIdentifier)
  39. headerView.delegate = self
  40. //headerView.frame = CGRect(x: 0, y: 0, width: SCREEN_WIDTH, height: 172)
  41. //tableView.tableHeaderView = headerView
  42. tableView.emptyDataSetSource = self
  43. tableView.emptyDataSetDelegate = self
  44. tableView.mj_header = MJRefreshNormalHeader(refreshingBlock: {
  45. self.loadData()
  46. })
  47. loadMeetConfig()
  48. loadData()
  49. }
  50. func loadMeetConfig() {
  51. viewModel.loadMeetingConfig().then { (config) in
  52. self.config = config
  53. if let c = self.config {
  54. if c.mobileCreateEnable == true {
  55. DispatchQueue.main.async {
  56. UIApplication.shared.windows.first?.addSubview(self.createView)
  57. }
  58. }
  59. }
  60. }.catch { (error) in
  61. DDLogError("会议配置获取异常, \(error)")
  62. }
  63. }
  64. func loadData() {
  65. self.showLoading()
  66. all(viewModel.getMeetingsByYearAndMonth(Date()), viewModel.getMeetingByTheDay(Date()))
  67. .always {
  68. self.hideLoading()
  69. if self.tableView.mj_header.isRefreshing() {
  70. self.tableView.mj_header.endRefreshing()
  71. }
  72. //self.tableView.reloadData()
  73. }
  74. .then { (result) in
  75. DispatchQueue.main.async {
  76. self.headerView.eventsByDate = result.0 as? [String: [OOMeetingInfo]]
  77. self.viewModel.theMeetingsByDay.removeAll()
  78. self.viewModel.theMeetingsByDay.append(contentsOf: result.1)
  79. self.tableView.reloadData()
  80. }
  81. }.catch { (myerror) in
  82. let customError = myerror as! OOAppError
  83. self.showError(title: customError.failureReason ?? "")
  84. }
  85. }
  86. func loadCurrentMonthCalendar(_ theDate: Date?) {
  87. self.showLoading()
  88. viewModel.getMeetingsByYearAndMonth(theDate ?? Date())
  89. .always {
  90. self.hideLoading()
  91. }
  92. .then { (resultDict) in
  93. self.headerView.eventsByDate = resultDict as? [String: [OOMeetingInfo]]
  94. }.catch { (myerror) in
  95. let customError = myerror as! OOAppError
  96. self.showError(title: customError.failureReason ?? "")
  97. }
  98. }
  99. func loadtheDayMeetingInfo(_ theDate: Date?) {
  100. self.showLoading()
  101. viewModel.getMeetingByTheDay(theDate ?? Date()).always {
  102. self.hideLoading()
  103. }.then { (infos) in
  104. self.viewModel.theMeetingsByDay.removeAll()
  105. self.viewModel.theMeetingsByDay.append(contentsOf: infos)
  106. self.tableView.reloadData()
  107. }.catch { (myerror) in
  108. let customError = myerror as! OOAppError
  109. self.showError(title: customError.failureReason ?? "")
  110. }
  111. }
  112. private func startProcess(processId: String, identity: String) {
  113. viewModel.startProcess(processId: processId, identity: identity).then { (list) in
  114. let taskList = list
  115. DispatchQueue.main.async {
  116. let taskStoryboard = UIStoryboard(name: "task", bundle: Bundle.main)
  117. let todoTaskDetailVC = taskStoryboard.instantiateViewController(withIdentifier: "todoTaskDetailVC") as! TodoTaskDetailViewController
  118. todoTaskDetailVC.todoTask = taskList[0].copyToTodoTask()
  119. todoTaskDetailVC.backFlag = 3
  120. self.navigationController?.pushViewController(todoTaskDetailVC, animated: true)
  121. }
  122. }.catch { (error) in
  123. self.showError(title: "启动会议流程出错!")
  124. }
  125. }
  126. override func didReceiveMemoryWarning() {
  127. super.didReceiveMemoryWarning()
  128. // Dispose of any resources that can be recreated.
  129. }
  130. override func viewWillAppear(_ animated: Bool) {
  131. super.viewWillAppear(animated)
  132. }
  133. override func viewWillDisappear(_ animated: Bool) {
  134. super.viewWillDisappear(animated)
  135. createView.removeFromSuperview()
  136. }
  137. }
  138. // MARK:- EmptyDataSetSource,EmptyDataSetDelegate
  139. extension OOMeetingInforController: EmptyDataSetSource, EmptyDataSetDelegate {
  140. func title(forEmptyDataSet scrollView: UIScrollView) -> NSAttributedString? {
  141. let text = "您当前还没有会议"
  142. let titleAttributes = [NSAttributedString.Key.foregroundColor: UIColor(hex: "#CCCCCC"), NSAttributedString.Key.font: UIFont.init(name: "PingFangSC-Regular", size: 18)!]
  143. return NSMutableAttributedString(string: text, attributes: titleAttributes)
  144. }
  145. func image(forEmptyDataSet scrollView: UIScrollView) -> UIImage? {
  146. return #imageLiteral(resourceName: "icon_wuhuiyi")
  147. }
  148. func backgroundColor(forEmptyDataSet scrollView: UIScrollView) -> UIColor? {
  149. return UIColor(hex: "#F5F5F5")
  150. }
  151. func emptyDataSetShouldDisplay(_ scrollView: UIScrollView) -> Bool {
  152. return true
  153. }
  154. }
  155. extension OOMeetingInforController: O2BBSCreatorViewDelegate {
  156. func creatorViewClicked(_ view: O2BBSCreatorView) {
  157. print("Creat Meeting")
  158. if let c = self.config, let pId = c.process?.id {
  159. self.showLoading(title: "Loading")
  160. viewModel.loadMeetingProcess(processId: pId).then { (list) in
  161. self.hideLoading()
  162. if list.count == 1 {
  163. self.startProcess(processId: pId, identity: list[0].distinguishedName!)
  164. } else {
  165. var actions: [UIAlertAction] = []
  166. list.forEach({ (identity) in
  167. let action = UIAlertAction(title: "\(identity.name!)(\(identity.unitName!))", style: .default, handler: { (a) in
  168. self.startProcess(processId: pId, identity: identity.distinguishedName!)
  169. })
  170. actions.append(action)
  171. })
  172. self.showSheetAction(title: "提示", message: "请选择创建会议流程的身份", actions: actions)
  173. }
  174. }.catch { (error) in
  175. DDLogError("\(error)")
  176. self.hideLoading()
  177. self.performSegue(withIdentifier: "showCreateMeetingSgue", sender: nil)
  178. }
  179. } else {
  180. self.performSegue(withIdentifier: "showCreateMeetingSgue", sender: nil)
  181. }
  182. }
  183. }
  184. // MARK:- OOMeetingInforHeaderViewDelegate
  185. extension OOMeetingInforController: OOMeetingInforHeaderViewDelegate {
  186. func selectedTheDay(_ theDay: Date?) {
  187. loadtheDayMeetingInfo(theDay)
  188. }
  189. func selectedTheMonth(_ theMonth: Date?) {
  190. loadCurrentMonthCalendar(theMonth)
  191. }
  192. }
  193. // MARK:- UITableViewDataSource,UITableViewDelegate
  194. extension OOMeetingInforController: UITableViewDataSource, UITableViewDelegate {
  195. func numberOfSections(in tableView: UITableView) -> Int {
  196. return viewModel.numberOfSections()
  197. }
  198. func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
  199. return viewModel.numberOfRowsInSection(section)
  200. }
  201. func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
  202. let cell = tableView.dequeueReusableCell(withIdentifier: meetingIdentifier, for: indexPath)
  203. let uCell = cell as! OOMeetingInforItemCell
  204. uCell.viewModel = viewModel
  205. let item = viewModel.nodeForIndexPath(indexPath)
  206. uCell.config(withItem: item)
  207. return cell
  208. }
  209. func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
  210. return 116.0
  211. }
  212. func tableView(_ tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat {
  213. return headerView.calendarManager?.settings.weekModeEnabled == false ? hSectionHeight : sectionHeight
  214. }
  215. func tableView(_ tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? {
  216. return headerView
  217. }
  218. }