notificationCtrl.js 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344
  1. 'use strict';
  2. /**
  3. * controller for User Profile Example
  4. */
  5. app.controller('notificationCtr', ["$rootScope", "$scope", "$state", "$timeout", "$interval", "$modal", "SweetAlert", "i18nService", "uiGridConstants", "uiGridGroupingConstants", "Restangular", "api_user_data", "api_login", "api_configure_data", "api_wechatfile", "api_notification_data", function ($rootScope, $scope, $state, $timeout, $interval, $modal, SweetAlert, i18nService, uiGridConstants, uiGridGroupingConstants, Restangular, api_user_data, api_login, api_configure_data, api_wechatfile, api_notification_data) {
  6. //侧边栏索引
  7. $scope.leftListIdx = 0;
  8. //标题
  9. $scope.tableName = "消息通知设置";
  10. //侧边栏名称
  11. $scope.listData = [
  12. { "name": "报修流程" },
  13. { "name": "事件流程" }
  14. // { "name": "上下班管理" }
  15. ];
  16. //转换通知规则
  17. $scope.computedRule = function (data, id) {
  18. if (data === undefined) {
  19. return '进入本步骤时';
  20. } else if (id == 6 || id == 7) {
  21. return '【逾期响应时间】' + data + '分钟';
  22. } else if (id == 11) {
  23. return '【解决时间】剩余 ' + data + '%';
  24. }
  25. };
  26. /**
  27. *
  28. * 侧边栏点击切换tab
  29. * @param {number} idx 当前点击的索引
  30. * @param {object} value 当前点击的对象
  31. */
  32. $scope.leftListClick = function (idx, value) {
  33. $scope.leftListIdx = idx;
  34. $scope.tableName = value.name;
  35. }
  36. //请求获取报修流程列表
  37. //process: '通知流程',processNode:'流程节点',processStatus:'状态',notifiedPerson:'被通知人'
  38. $scope.bxList = [
  39. { processName: '报修流程', processNode: '申请', processStatus: '未转换', notifiedPerson: '报修人' },
  40. { processName: '报修流程', processNode: '申请', processStatus: '未转换', notifiedPerson: '服务台人员' },
  41. { processName: '报修流程', processNode: '申请', processStatus: '不受理', notifiedPerson: '报修人' },
  42. { processName: '报修流程', processNode: '受理', processStatus: '已转换', notifiedPerson: '报修人' }
  43. ];
  44. $scope.getBxList = function () {
  45. api_notification_data.fetchDataList({
  46. "idx": 0,
  47. "sum": 10,
  48. "messageManager": {
  49. "noticeProcess": 1
  50. }
  51. }).then(function (res) {
  52. if (res.status == 200) {
  53. angular.forEach($scope.bxList, function (v, i) {
  54. angular.extend(v, res.list[i]);//合并对象
  55. })
  56. }
  57. })
  58. }
  59. $scope.getBxList();
  60. //请求获取事件流程列表
  61. //process: '通知流程',processNode:'流程节点',processStatus:'状态',notifiedPerson:'被通知人'
  62. $scope.sjList = [
  63. { processName: '事件流程', processNode: '接单', processStatus: '待接单', notifiedPerson: '运维工程师' },
  64. { processName: '事件流程', processNode: '接单', processStatus: '待接单', notifiedPerson: '运维工程师' },
  65. { processName: '事件流程', processNode: '接单', processStatus: '待接单', notifiedPerson: '事件经理' },
  66. { processName: '事件流程', processNode: '重新指派', processStatus: '重新指派', notifiedPerson: '服务台人员' },
  67. { processName: '事件流程', processNode: '重新指派', processStatus: '重新指派', notifiedPerson: '运维工程师' },
  68. { processName: '事件流程', processNode: '处理', processStatus: '处理中', notifiedPerson: '报修人' },
  69. { processName: '事件流程', processNode: '处理', processStatus: '处理中', notifiedPerson: '运维工程师' },
  70. { processName: '事件流程', processNode: '评价', processStatus: '已解决', notifiedPerson: '报修人' },
  71. { processName: '事件流程', processNode: '关单', processStatus: '已解决', notifiedPerson: '服务台人员' },
  72. { processName: '事件流程', processNode: '完成', processStatus: '已关闭', notifiedPerson: '报修人' }
  73. ];
  74. $scope.getSjList = function () {
  75. api_notification_data.fetchDataList({
  76. "idx": 0,
  77. "sum": 10,
  78. "messageManager": {
  79. "noticeProcess": 2
  80. }
  81. }).then(function (res) {
  82. if (res.status == 200) {
  83. angular.forEach($scope.sjList, function (v, i) {
  84. angular.extend(v, res.list[i]);//合并对象
  85. })
  86. console.log($scope.sjList)
  87. }
  88. })
  89. }
  90. $scope.getSjList();
  91. //设置
  92. $scope.editClick = function (data) {
  93. var modalInstance = $modal.open({
  94. templateUrl: 'assets/views/system/tpl/notificationBj.html',
  95. controller: function ($scope, $modalInstance) {
  96. $scope.editData = {
  97. id: data.id,//id
  98. noticeRule: data.noticeRule === undefined ? 'no' : data.noticeRule,//通知规则,数字
  99. processNode: data.processNode,//流程节点
  100. processName: data.processName,//报修流程或者事件流程
  101. processStatus: data.processStatus,//状态
  102. notifiedPerson: data.notifiedPerson,//被通知人
  103. noticeProcess: data.noticeProcess,//1为报修流程、2为事件流程
  104. messageStationContent: data.messageStationContent,//站内消息通知内容
  105. shortMessageContent: data.shortMessageContent,//短信通知内容
  106. wechatMessageContent: data.wechatMessageContent,//微信通知内容
  107. messageStationFlag: data.messageStationFlag == 1 ? true : false,//站内消息是否开启
  108. shortMessageFlag: data.shortMessageFlag == 1 ? true : false,//短信是否开启
  109. wechatMessageFlag: data.wechatMessageFlag == 1 ? true : false,//微信是否开启
  110. messageStationTitle: data.messageStationTitle,//站内消息标题
  111. wechatMessageTitle: data.wechatMessageTitle,//微信标题
  112. flag: data.flag == 1 ? true : false//总开关是否开启,0为关闭,1为开启
  113. };
  114. //当前选中
  115. $scope.currentIndex = 0;
  116. //tab页面数据
  117. //tabName: 名称,processTitle:标题, processContent: 内容, checkboxFlag: checkbox是否选中,,disable:遮罩是否显示
  118. $scope.tabs = [
  119. {
  120. tabName: "站内消息",
  121. processTitle: $scope.editData.messageStationTitle,
  122. processContent: $scope.editData.messageStationContent,
  123. checkboxFlag: $scope.editData.messageStationFlag,
  124. disable: !$scope.editData.messageStationFlag
  125. },
  126. {
  127. tabName: "短信",
  128. processTitle: '',
  129. processContent: $scope.editData.shortMessageContent,
  130. checkboxFlag: $scope.editData.shortMessageFlag,
  131. disable: !$scope.editData.shortMessageFlag
  132. },
  133. {
  134. tabName: "微信",
  135. processTitle: $scope.editData.wechatMessageTitle,
  136. processContent: $scope.editData.wechatMessageContent,
  137. checkboxFlag: $scope.editData.wechatMessageFlag,
  138. disable: !$scope.editData.wechatMessageFlag
  139. }
  140. ];
  141. //tab页面切换
  142. $scope.selectTab = function (index) {
  143. $scope.currentIndex = index;
  144. };
  145. //checkbox选中或者取消
  146. $scope.selectThis = function (index) {
  147. $scope.tabs[index].checkboxFlag = !$scope.tabs[index].checkboxFlag;
  148. //遮罩切换
  149. $scope.tabs[index].disable = !$scope.tabs[index].checkboxFlag;
  150. //所有checkbox有一个选中,总开关开启
  151. $scope.editData.flag = $scope.tabs.some(function (v) {
  152. return v.checkboxFlag;
  153. });
  154. };
  155. //切换总开关
  156. $scope.changeIcon = function (index) {
  157. $scope.editData.flag = !$scope.editData.flag;
  158. };
  159. //当前jquery对象
  160. $scope.curElement = null;
  161. //textarea失去焦点,允许插入的表单元素
  162. $scope.textBlur = function ($event) {
  163. $scope.curElement = $($event.target);
  164. };
  165. //插入值
  166. $scope.insertClick = function ($event) {
  167. var $_this = $($event.target);
  168. var str = "";
  169. if ($scope.curElement != null) {
  170. //获取插入的字符串
  171. str = $_this.text();
  172. //插入进去
  173. $scope.insertAtCaret($scope.curElement, str);
  174. }
  175. };
  176. //插入进去seimin
  177. $scope.insertAtCaret = function ($element, myValue) {
  178. var element = $element.get(0);
  179. if (document.selection) {//IE
  180. $element.focus();
  181. //在选中区域创建一个文本区域
  182. sel = document.selection.createRange();
  183. // sel.text = myValue;
  184. $scope.tabs[$scope.currentIndex].processContent = myValue;
  185. $element.focus();
  186. } else {
  187. if (element.selectionStart || element.selectionStart == '0') {
  188. var startPos = element.selectionStart;
  189. var endPos = element.selectionEnd;
  190. // element.value = element.value.substring(0, startPos) + myValue + element.value.substring(endPos);
  191. $scope.tabs[$scope.currentIndex].processContent = element.value.substring(0, startPos) + myValue + element.value.substring(endPos);
  192. $element.focus();
  193. } else {
  194. var val = $element.html() + myValue;
  195. // $element.html(val);
  196. $scope.tabs[$scope.currentIndex].processContent = val;
  197. $element.focus();
  198. }
  199. }
  200. };
  201. //百分比不能为负数
  202. $scope.$watch('editData.noticeRule', function (newVal) {
  203. if (newVal === undefined) {//负号
  204. $scope.editData.noticeRule = 0;
  205. } else {
  206. if ($scope.editData.id == 11) {//百分比
  207. $scope.editData.noticeRule = newVal < 0 ? 0 : newVal;
  208. }
  209. }
  210. });
  211. //变量参数
  212. switch ($scope.editData.id) {
  213. case 1:
  214. $scope.varArr = ['[$报修单号$]', '[$报修时间$]', '[$报修人$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  215. $scope.varPlaceholder = '您于${报修时间}申请的${区域}${地点}${详细地址}${报修单号}报修已提交,请等待服务台处理,如有疑问,可(咨询电话"123456")。';
  216. break;
  217. case 2:
  218. $scope.varArr = ['[$报修单号$]', '[$报修时间$]', '[$报修人$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  219. $scope.varPlaceholder = '${报修单号}报修待受理,请及时处理。';
  220. break;
  221. case 3:
  222. $scope.varArr = ['[$报修单号$]', '[$报修时间$]', '[$报修人$]', '[$服务台人员$]', '[$不受理时间$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  223. $scope.varPlaceholder = '您于${报修时间}${区域}${地点}${详细地址}的${报修单号}报修,${服务台人员}已于${不受理时间}不予受理,如有如有疑问请拨打(服务电话“123456”)。';
  224. break;
  225. case 4:
  226. $scope.varArr = ['[$报修单号$]', '[$报修时间$]', '[$报修人$]', '[$服务台人员$]', '[$受理时间$]', '[$处理人$]', '[$处理人电话$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  227. $scope.varPlaceholder = '您于${报修时间}${区域}${地点}${详细地址}的${报修单号}报修,${服务台人员}已于${受理时间}受理,待接单。';
  228. break;
  229. case 5:
  230. $scope.varArr = ['[$事件单号$]', '[$工单登记时间$]', '[$故障地点$]', '[$联系人$]', '[$联系人电话$]', '[$受理人$]', '[$受理人电话$]', '[$处理人$]', '[$处理人电话$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  231. $scope.varPlaceholder = '${ 联系人}${联系人电话}于${工单登记时间}${事件单号}的事件工单待接单,请尽快处理。';
  232. break;
  233. case 6:
  234. $scope.varArr = ['[$事件单号$]', '[$工单登记时间$]', '[$故障地点$]', '[$联系人$]', '[$联系人电话$]', '[$受理人$]', '[$受理人电话$]', '[$处理人$]', '[$处理人电话$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  235. $scope.varPlaceholder = '${联系人}${联系人电话}于${工单登记时间}${事件单号}的事件工单待接单,已逾期响应5分钟,请尽快处理。';
  236. break;
  237. case 7:
  238. $scope.varArr = ['[$事件单号$]', '[$工单登记时间$]', '[$故障地点$]', '[$联系人$]', '[$联系人电话$]', '[$受理人$]', '[$受理人电话$]', '[$处理人$]', '[$处理人电话$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  239. $scope.varPlaceholder = '${联系人}${联系人电话}于${工单登记时间}${事件单号}的事件工单待接单,已逾期响应60分钟,${处理人}${处理人电话}请尽快处理。';
  240. break;
  241. case 8:
  242. $scope.varArr = ['[$事件单号$]', '[$工单登记时间$]', '[$故障地点$]', '[$联系人$]', '[$联系人电话$]', '[$受理人$]', '[$受理人电话$]', '[$处理人$]', '[$处理人电话$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  243. $scope.varPlaceholder = '${ 联系人}${联系人电话}于${工单登记时间}${事件单号}的事件工单,${处理人}${处理人电话}已请求重新指派,请尽快处理。';
  244. break;
  245. case 9:
  246. $scope.varArr = ['[$事件单号$]', '[$工单登记时间$]', '[$故障地点$]', '[$联系人$]', '[$联系人电话$]', '[$受理人$]', '[$受理人电话$]', '[$处理人$]', '[$处理人电话$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  247. $scope.varPlaceholder = '${联系人}${联系人电话}于${工单登记时间}${事件单号}的事件工单,已退回服务台,请重新指派。';
  248. break;
  249. case 10:
  250. $scope.varArr = ['[$报修单号$]','[$报修时间$]','[$故障地点$]', '[$联系人$]', '[$联系人电话$]', '[$受理人$]', '[$受理人电话$]', '[$处理人$]', '[$处理人电话$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  251. $scope.varPlaceholder = '${联系人}${联系人电话}于${报修时间}${报修单号}的报修,${处理人}${处理人电话}已接单,正在处理中。';
  252. break;
  253. case 11:
  254. $scope.varArr = ['[$事件单号$]', '[$工单登记时间$]', '[$故障地点$]', '[$联系人$]', '[$联系人电话$]', '[$受理人$]', '[$受理人电话$]', '[$处理人$]', '[$处理人电话$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  255. $scope.varPlaceholder = '${联系人}${联系人电话}于${工单登记时间}${事件单号}的事件工单,即将解决逾期,请尽快处理。';
  256. break;
  257. case 12:
  258. $scope.varArr = ['[$报修单号$]','[$报修时间$]','[$故障地点$]', '[$联系人$]', '[$联系人电话$]', '[$受理人$]', '[$受理人电话$]', '[$处理人$]', '[$处理人电话$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  259. $scope.varPlaceholder = '您于${报修时间}提交的${报修单号}报修,已处理,您可对本次服务进行评价,如有疑问,可(咨询电话“123456”)。';
  260. break;
  261. case 13:
  262. $scope.varArr = ['[$事件单号$]', '[$工单登记时间$]', '[$故障地点$]', '[$联系人$]', '[$联系人电话$]', '[$受理人$]', '[$受理人电话$]', '[$处理人$]', '[$处理人电话$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  263. $scope.varPlaceholder = '${联系人}${联系人电话}于${工单登记时间}${事件单号}的事件工单已解决,请回访并关闭该工单。';
  264. break;
  265. case 14:
  266. $scope.varArr = ['[$报修单号$]', '[$报修时间$]', '[$故障地点$]', '[$联系人$]', '[$联系人电话$]', '[$受理人$]', '[$受理人电话$]', '[$处理人$]', '[$处理人电话$]', '[$事件描述$]', '[$区域$]', '[$地点$]', '[$详细地址$]'];
  267. $scope.varPlaceholder = '您于${报修时间}提交的${报修单号}报修,已完成,如有疑问,请拔打(服务电话“123456”)。';
  268. break;
  269. }
  270. //取消
  271. $scope.cancel = function () {
  272. $modalInstance.dismiss('cancel');
  273. };
  274. //确定seimin
  275. $scope.savercode = function () {
  276. var filterArr = $scope.tabs.filter(item => {
  277. return item.checkboxFlag;
  278. });
  279. for (var i = 0; i < filterArr.length; i++) {
  280. if (filterArr[i].processContent == '') {
  281. alert("通知内容【" + filterArr[i].tabName + "】不能为空!");
  282. return;
  283. } else {
  284. var nowArr = [...new Set([...filterArr[i].processContent.match(/\[\$[^\$\[\]]*?\$\]/g), ...$scope.varArr])];
  285. if (nowArr.length !== $scope.varArr.length) {
  286. alert("【" + filterArr[i].tabName + "】请填写有效的变量名称!");
  287. return;
  288. }
  289. }
  290. }
  291. //请求参数处理(是否有输入数字控件)
  292. if ($scope.editData.noticeRule !== 'no') {
  293. var data = {
  294. "messageManager": {
  295. "id": $scope.editData.id,
  296. "noticeRule": $scope.editData.noticeRule,
  297. "messageStationFlag": $scope.tabs[0].checkboxFlag ? 1 : 0,
  298. "messageStationTitle": $scope.tabs[0].processTitle,
  299. "messageStationContent": $scope.tabs[0].processContent,
  300. "shortMessageFlag": $scope.tabs[1].checkboxFlag ? 1 : 0,
  301. "shortMessageContent": $scope.tabs[1].processContent,
  302. "wechatMessageFlag": $scope.tabs[2].checkboxFlag ? 1 : 0,
  303. "wechatMessageTitle": $scope.tabs[2].processTitle,
  304. "wechatMessageContent": $scope.tabs[2].processContent,
  305. "flag": $scope.editData.flag ? 1 : 0
  306. }
  307. };
  308. } else {
  309. var data = {
  310. "messageManager": {
  311. "id": $scope.editData.id,
  312. "messageStationFlag": $scope.tabs[0].checkboxFlag ? 1 : 0,
  313. "messageStationTitle": $scope.tabs[0].processTitle,
  314. "messageStationContent": $scope.tabs[0].processContent,
  315. "shortMessageFlag": $scope.tabs[1].checkboxFlag ? 1 : 0,
  316. "shortMessageContent": $scope.tabs[1].processContent,
  317. "wechatMessageFlag": $scope.tabs[2].checkboxFlag ? 1 : 0,
  318. "wechatMessageTitle": $scope.tabs[2].processTitle,
  319. "wechatMessageContent": $scope.tabs[2].processContent,
  320. "flag": $scope.editData.flag ? 1 : 0
  321. }
  322. };
  323. }
  324. // 关闭模态窗口并传递一个结果
  325. $modalInstance.close(data);
  326. };
  327. }
  328. });
  329. modalInstance.result.then(function (data) {
  330. api_notification_data.updData(data).then(function (res) {
  331. if (res.status == 200) {
  332. SweetAlert.swal({
  333. title: "修改成功!",
  334. type: "success",
  335. confirmButtonColor: "#007AFF"
  336. }, function () {
  337. $scope.getBxList();
  338. $scope.getSjList();
  339. });
  340. }
  341. })
  342. });
  343. }
  344. }]);