specialPersonnel.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. define(function (require) {
  2. return function (context) {
  3. var $grid1, $form;
  4. // 输入搜索文本后点击回车按钮查询列表
  5. function enterQueryGrid1(e) {
  6. if (e.keyCode === 13) {
  7. var tmp = $(this).val();
  8. $form.formSet({queryProperties: tmp});
  9. queryGrid1();
  10. }
  11. }
  12. // 检索条件查询
  13. function queryGrid1() {
  14. var queryForm = $form.formGet();
  15. queryForm.tuType = 2;
  16. $grid1.reload({
  17. mtype: 'POST',
  18. url: api('/OutUser/selectAllOutUser'),
  19. queryParams: queryForm
  20. }, true);
  21. }
  22. var queryToolbar = {
  23. xtype: 'toolbar',
  24. title: '特殊人员详情',
  25. items: [
  26. {
  27. text: '查询', iconCls: 'fa fa-search', onClick: function () {
  28. queryGrid1();
  29. }
  30. }, {
  31. text: '重置', iconCls: 'fa fa-refresh', onClick: function () {
  32. $form.formClear();
  33. queryGrid1();
  34. }
  35. }, {
  36. text: '关闭', iconCls: 'fa fa-times-circle', onClick: function () {
  37. App.closeMe(this);
  38. }
  39. }
  40. ]
  41. };
  42. var queryForm = {
  43. onRender: function () {
  44. $form = $(this);
  45. },
  46. xtype: 'form',
  47. items: [[
  48. {
  49. xtype: 'textbox',
  50. label: '检索条件',
  51. name: 'queryProperties',
  52. prompt: "小区名称/联系人姓名",
  53. labelWidth: 'auto',
  54. events: {keydown: enterQueryGrid1}, width: 350
  55. },
  56. {
  57. xtype: 'textbox',
  58. label: '电话',
  59. name: 'phone',
  60. prompt: "小区名称",
  61. labelWidth: 'auto',
  62. events: {keydown: enterQueryGrid1}, width: 350
  63. },
  64. ]]
  65. };
  66. return {
  67. north: {
  68. height: 88,
  69. /* split: true,
  70. border: false,*///底框是否可变动
  71. items: [
  72. queryToolbar,
  73. queryForm
  74. ]
  75. },
  76. center: {
  77. height: '60%',
  78. split: true,
  79. items:
  80. {
  81. onRender: function () {
  82. $grid1 = $(this);
  83. queryGrid1()
  84. },
  85. xtype: 'grid',
  86. toolbar: {
  87. xtype: 'toolbar',
  88. title: '特殊人员详情',
  89. items: [
  90. {
  91. text: '添加', iconCls: 'fa fa-plus-circle fa-lg', onClick: function () {
  92. $.yvan.showDialog(this,
  93. require('/app/whepi/scan/addOutUser.js')({
  94. isEdit: false,
  95. confirm: function () {
  96. queryGrid1();
  97. }
  98. })
  99. );
  100. }
  101. },
  102. // {
  103. // text: '保存', iconCls: 'fa fa-pencil-square-o', onClick: function () {
  104. // var row = $grid1.rowData();
  105. // if (!row) {
  106. // $.yvan.msg('请选择一条要保存的数据');
  107. // return;
  108. // }
  109. // var startDateStr = row.startDateStr;
  110. // var endDateStr = row.endDateStr;
  111. // if (startDateStr > endDateStr) {
  112. // $.yvan.msg('开始时间必须小于等于结束时间');
  113. // return;
  114. // }
  115. // $.yvan.ajax({
  116. // url: api('/OutUser/updateOutUser'),
  117. // data: {
  118. // tuId: row.tuId,
  119. // startDate: row.startDateStr,
  120. // endDate: row.endDateStr
  121. // },
  122. // method: 'post',
  123. // async: false,
  124. // success: function (data) {
  125. // $.yvan.msg("操作成功");
  126. // $grid1.reload();
  127. // queryGrid1();
  128. // }
  129. // });
  130. // }
  131. // },
  132. {
  133. text: '删除', iconCls: 'fa fa fa-pencil-square-o fa-lg', onClick: function () {
  134. var row = $grid1.checkedData();
  135. if (row.length == 0) {
  136. $.yvan.msg('请至少选择一行数据');
  137. return;
  138. }
  139. var ids = "";
  140. for (var i=0; i<row.length; i++) {
  141. ids += row[i].tuId + ","
  142. }
  143. $.yvan.confirm('确定删除勾选的这' + row.length + '条特殊人员吗?', {
  144. yes: function (index) {
  145. $.yvan.ajax({
  146. method: 'post',
  147. url: api('/OutUser/deleteOutUser'),
  148. data: {ids: ids},
  149. success: function (data) {
  150. $.yvan.msg("删除成功");
  151. $grid1.reload();
  152. queryGrid1();
  153. }
  154. });
  155. }
  156. });
  157. }
  158. }
  159. ]
  160. },
  161. multiselect: true, /// 表格多选
  162. idField: 'tuId',
  163. editable: true,
  164. editOnSelected: true,
  165. autoSizeColumns: true,
  166. columns:
  167. [
  168. [
  169. {field: 'tuId', title: '用户ID', hidden: true},
  170. {field: 'userId', title: '用户ID', hidden: true},
  171. {field: 'uptownName', title: '小区', maxWidth: 200, align: 'left',},
  172. {field: 'ridgepole', title: '栋', maxWidth: 200, align: 'left',},
  173. {field: 'unit', title: '单元', maxWidth: 200, align: 'left',},
  174. {field: 'name', title: '名字', maxWidth: 200, align: 'left',},
  175. {field: 'phone', title: '电话', maxWidth: 200, align: 'left',},
  176. {field: 'doorplate', title: '门牌', maxWidth: 200, align: 'left',},
  177. {
  178. field: 'startDateStr', title: '开始时间', minWidth: 120, maxWidth: 300, align: 'left', editor: {
  179. xtype: 'datebox',
  180. required: true,
  181. onChange: function (value) {
  182. console.log(value)
  183. var row = $grid1.rowData();
  184. var startDateStr = row.startDateStr;
  185. var endDateStr = row.endDateStr;
  186. if (startDateStr > endDateStr) {
  187. $.yvan.msg('开始时间必须小于等于结束时间');
  188. return;
  189. } else {
  190. $.yvan.ajax({
  191. url: api('/OutUser/updateOutUser'),
  192. data: {
  193. tuId: row.tuId,
  194. startDate: row.startDateStr,
  195. endDate: row.endDateStr
  196. },
  197. method: 'post',
  198. async: false,
  199. success: function (data) {
  200. $.yvan.msg("操作成功");
  201. return;
  202. }
  203. });
  204. }
  205. },
  206. maxlength: 50
  207. }
  208. },
  209. {
  210. field: 'endDateStr', title: '结束时间', minWidth: 120, maxWidth: 200, align: 'left', editor: {
  211. xtype: 'datebox',
  212. required: true,
  213. onChange: function (value, oldValue) {
  214. console.log(value)
  215. var row = $grid1.rowData();
  216. var startDateStr = row.startDateStr;
  217. var endDateStr = row.endDateStr;
  218. if (startDateStr > endDateStr) {
  219. $.yvan.msg('开始时间必须小于等于结束时间');
  220. return;
  221. } else {
  222. $.yvan.ajax({
  223. url: api('/OutUser/updateOutUser'),
  224. data: {
  225. tuId: row.tuId,
  226. startDate: row.startDateStr,
  227. endDate: row.endDateStr
  228. },
  229. method: 'post',
  230. async: false,
  231. success: function (data) {
  232. $.yvan.msg("操作成功");
  233. return;
  234. }
  235. });
  236. }
  237. },
  238. maxlength: 50
  239. }
  240. },
  241. ]
  242. ]
  243. }
  244. }
  245. };
  246. };
  247. }
  248. );