talentAllowanceInfo_select.js 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453
  1. /**
  2. * 初始化人才认定申报详情对话框
  3. */
  4. var TalentAllowanceInfoDlg = {
  5. talentAllowanceData: {},
  6. validateFields: {
  7. talentId: {validators: {notEmpty: {message: '申报对象不能为空'}}}
  8. }
  9. };
  10. //初始化附件类别表单
  11. TalentAllowanceInfoDlg.initFileTable = function () {
  12. TalentAllowanceInfoDlg.initContract();
  13. var queryData = {};
  14. queryData["mainId"] = $("#id").val();
  15. queryData['project'] = CONFIG.project_jbt;
  16. queryData['type'] = $("#type").val();
  17. queryData['allowanceType'] = $("#allowanceType").val();
  18. $("#fileTable").bootstrapTable({
  19. url: Feng.ctxPath + "/common/api/findCommonFileType",
  20. method: 'POST',
  21. contentType: "application/x-www-form-urlencoded; charset=UTF-8",
  22. search: false, // 是否显示表格搜索,此搜索是客户端搜索,不会进服务端
  23. showRefresh: false, // 是否显示刷新按钮
  24. clickToSelect: true, // 是否启用点击选中行
  25. singleSelect: true, // 设置True 将禁止多选
  26. striped: true, // 是否显示行间隔色
  27. escape: true,
  28. pagination: false, // 设置为 true 会在表格底部显示分页条
  29. paginationHAlign: "left",
  30. paginationDetailHAlign: "right",
  31. sidePagination: "server", // 设置在哪里进行分页,可选值为 'client' 或者 'server'
  32. showColumns: false,
  33. detailView: true, //是否显示父子表
  34. pageList: [10, 30, 50],
  35. queryParams: function (params) {
  36. return $.extend(queryData, params)
  37. },
  38. rowStyle: function (row, index) {
  39. return {classes: "info"};
  40. },
  41. columns: TalentAllowanceInfoDlg.initFileTypeColumn(),
  42. onPostBody: function () {
  43. $("td.uitd_showTip").bind("mouseover", function () {
  44. var htm = $(this).html();
  45. $(this).webuiPopover({title: '详情', content: htm, trigger: 'hover'}).webuiPopover('show');
  46. });
  47. },
  48. onLoadSuccess: function (data) {
  49. $("#fileTable").bootstrapTable('expandAllRows');
  50. },
  51. onExpandRow: function (index, row, $detail) {
  52. var ajax = new $ax(Feng.ctxPath + "/common/api/listTalentFile", function (data) {
  53. if (data == null || data.length == 0) {
  54. return;
  55. }
  56. var html = '<ul class="imgs"><li style="width: 80%;font-weight: bold;padding-top: 5px;">附件原名</li><li style="width: 10%;font-weight: bold;padding-top: 5px;">预览</li>';
  57. for (var key in data) {
  58. var sn = data[key].url.lastIndexOf(".");
  59. var suffix = data[key].url.substring(sn + 1, data[key].url.length);
  60. var imgStr = "";
  61. if (suffix == "pdf" || suffix == "PDF") {
  62. imgStr = "<button type='button' onclick=\"Feng.showPdf('" + data[key].url + "','" + data[key].id + "','" + data[key].orignName + "')\" class=\"btn btn-xs btn-danger\"><i class=\"fa fa-file-pdf-o\" aria-hidden=\"true\"></i></button>";
  63. } else if (suffix == "xlsx" || suffix == "XLSX" || suffix == 'xls' || suffix == 'XLS') {
  64. imgStr = "<button type='button' onclick=\"Feng.showExcel('" + data[key].url + "','" + data[key].id + "','" + data[key].orignName + "')\" class=\"btn btn-xs btn-danger\"><i class=\"fa fa-file-excel-o\" aria-hidden=\"true\"></i></button>";
  65. } else if (suffix == "zip" || suffix == "rar" || suffix == '7z' || suffix == "ZIP" || suffix == "RAR" || suffix == '7Z') {
  66. imgStr = '<a href=\"' + data[key].url + '\">' + data[key].orignName + '</a>';
  67. } else if (suffix == "doc" || suffix == "DOC" || suffix == 'docx' || suffix == "DOCX") {
  68. imgStr = '<a href=\"' + data[key].url + '\">' + data[key].orignName + '</a>';
  69. } else {
  70. imgStr = '<img class=\"imgUrl\" src=\"' + data[key].url + '\" style=\"width:25px;height:25px;\">';
  71. }
  72. html = html + '<li style="display: none">' + data[key].id + '</li>\n' +
  73. '<li style="width: 80%;padding-top: 5px;">' + data[key].orignName + '</li>\n' +
  74. '<li style="width: 10%;">' + imgStr + '</li>\n';
  75. }
  76. html = html + '</ul>';
  77. $detail.html(html);
  78. $(".imgs").viewer({
  79. fullscreen: false
  80. });
  81. }, function (data) {
  82. Feng.error("查询失败!" + data.responseJSON.message + "!");
  83. });
  84. var queryData = {};
  85. queryData["mainId"] = $("#id").val();
  86. queryData["fileTypeId"] = row.id;
  87. ajax.set(queryData);
  88. ajax.start();
  89. }
  90. });
  91. TalentAllowanceInfoDlg.initCommonFileTable();
  92. }
  93. //初始化通用附件
  94. TalentAllowanceInfoDlg.initCommonFileTable = function () {
  95. var queryData = {};
  96. queryData.id = $("#id").val();
  97. $("#commonFileTable").bootstrapTable({
  98. url: Feng.ctxPath + "/common/api/listTalentAllowanceCommonFile",
  99. method: 'POST',
  100. contentType: "application/x-www-form-urlencoded; charset=UTF-8",
  101. search: false, // 是否显示表格搜索,此搜索是客户端搜索,不会进服务端
  102. showRefresh: false, // 是否显示刷新按钮
  103. clickToSelect: true, // 是否启用点击选中行
  104. singleSelect: true, // 设置True 将禁止多选
  105. striped: true, // 是否显示行间隔色
  106. pagination: false, // 设置为 true 会在表格底部显示分页条
  107. paginationHAlign: "left",
  108. paginationDetailHAlign: "right",
  109. sidePagination: "server", // 设置在哪里进行分页,可选值为 'client' 或者 'server'
  110. showColumns: false,
  111. queryParams: function (params) {
  112. return $.extend(queryData, params)
  113. },
  114. rowStyle: function (row, index) {
  115. return {css: {"word-break": "break-word", "white-space": "inherit"}}
  116. },
  117. columns: [
  118. {title: '附件原名', field: 'originalName', visible: true, align: 'center', valign: 'middle', 'class': 'uitd_showTip', width: '60%', formatter: function (value, row, index) {
  119. return value;
  120. }},
  121. {title: '附件类型', field: 'fileTypeName', visible: true, align: 'center', valign: 'middle', 'class': 'uitd_showTip', width: '20%', formatter: function (value, row, index) {
  122. return value;
  123. }},
  124. {title: '预览', field: 'url', visible: true, align: 'center', valign: 'middle', width: "20%",
  125. formatter: function (value, row, index) {
  126. var sn = value.lastIndexOf(".");
  127. var suffix = value.substring(sn + 1, value.length);
  128. var imgStr = "";
  129. if (suffix == "pdf" || suffix == "PDF") {
  130. imgStr = "<button type='button' onclick=\"Feng.showPdf('" + value + "','" + row.id + "','" + row.originalName + "')\" class=\"btn btn-xs btn-danger\"><i class=\"fa fa-file-pdf-o\" aria-hidden=\"true\"></i></button>";
  131. } else if (suffix == "xlsx" || suffix == "XLSX" || suffix == 'xls' || suffix == 'XLS') {
  132. imgStr = "<button type='button' onclick=\"Feng.showExcel('" + value + "','" + row.id + "','" + row.originalName + "')\" class=\"btn btn-xs btn-danger\"><i class=\"fa fa-file-excel-o\" aria-hidden=\"true\"></i></button>";
  133. } else {
  134. imgStr = '<img class=\"cImgUrl\" src=\"' + value + '\" style=\"width:25px;height:25px;\">';
  135. }
  136. return imgStr;
  137. }
  138. }
  139. ],
  140. onPostBody: function () {
  141. $("td.uitd_showTip").bind("mouseover", function () {
  142. var htm = $(this).html();
  143. $(this).webuiPopover({title: '详情', content: htm, trigger: 'hover'}).webuiPopover('show');
  144. });
  145. $(".cImgUrl").viewer({fullscreen: false});
  146. }
  147. });
  148. }
  149. /**
  150. * 初始化工作单位及核查项目情况表
  151. */
  152. TalentAllowanceInfoDlg.initContract = function () {
  153. $("#projectTable").bootstrapTable("destroy", {});
  154. $("#projectTable").bootstrapTable({
  155. url: Feng.ctxPath + "/enterprise/talentAllowance/findAllowanceContractDetail",
  156. method: 'POST',
  157. contentType: "application/x-www-form-urlencoded; charset=UTF-8",
  158. search: false, // 是否显示表格搜索,此搜索是客户端搜索,不会进服务端
  159. showRefresh: false, // 是否显示刷新按钮
  160. clickToSelect: true, // 是否启用点击选中行
  161. singleSelect: true, // 设置True 将禁止多选
  162. striped: true, // 是否显示行间隔色
  163. escape: true,
  164. pagination: false, // 设置为 true 会在表格底部显示分页条
  165. paginationHAlign: "left",
  166. paginationDetailHAlign: "right",
  167. sidePagination: "server", // 设置在哪里进行分页,可选值为 'client' 或者 'server'
  168. showColumns: false,
  169. detailView: true, //父子表
  170. queryParams: function (params) {
  171. return $.extend({"mainId": $("#id").val()}, params)
  172. },
  173. columns: TalentAllowanceInfoDlg.initContractColumns(),
  174. onPostBody: function () {
  175. $("td.uitd_showTip").bind("mouseover", function () {
  176. var htm = $(this).html();
  177. $(this).webuiPopover({title: '详情', content: htm, trigger: 'hover'}).webuiPopover('show');
  178. });
  179. },
  180. onLoadSuccess: function (data) {
  181. $("#projectTable").bootstrapTable('expandAllRows');
  182. },
  183. onExpandRow: function (index, row, $detail) {
  184. var enterpriseId = row.enterpriseId;
  185. var cur_table = $detail.html('<table id="' + enterpriseId + '" class="mytable-hover"></table>').find('table');
  186. $(cur_table).bootstrapTable("destroy", {});
  187. $(cur_table).bootstrapTable({
  188. url: Feng.ctxPath + "/enterprise/talentAllowance/findAllowanceProject",
  189. method: 'POST',
  190. contentType: "application/x-www-form-urlencoded; charset=UTF-8",
  191. search: false, // 是否显示表格搜索,此搜索是客户端搜索,不会进服务端
  192. showRefresh: false, // 是否显示刷新按钮
  193. clickToSelect: true, // 是否启用点击选中行
  194. singleSelect: true, // 设置True 将禁止多选
  195. escape: true,
  196. pagination: false, // 设置为 true 会在表格底部显示分页条
  197. paginationHAlign: "left",
  198. paginationDetailHAlign: "right",
  199. sidePagination: "server", // 设置在哪里进行分页,可选值为 'client' 或者 'server'
  200. showColumns: false,
  201. queryParams: function (params) {
  202. return $.extend({"mainId": $("#id").val(), "baseId": row.id}, params)
  203. },
  204. columns: TalentAllowanceInfoDlg.initProjectColumns(),
  205. });
  206. }
  207. });
  208. }
  209. //初始化工作单位表的列
  210. TalentAllowanceInfoDlg.initContractColumns = function () {
  211. var type = $("#type").val();
  212. if (type == 1) {
  213. return [
  214. {field: 'selectItem', checkbox: false, visible: false},
  215. {title: '企业名称', field: 'enterpriseName', visible: true, align: 'center', valign: 'middle', width: "120px", 'class': 'uitd_showTip'},
  216. {title: '合同起始时间', field: 'startTime', visible: true, align: 'center', valign: 'middle', width: "120px", 'class': 'uitd_showTip'},
  217. {title: '合同截止时间', field: 'endTime', visible: true, align: 'center', valign: 'middle', width: "120px", 'class': 'uitd_showTip'},
  218. {title: '入职时间', field: 'entryTime', visible: true, align: 'center', valign: 'middle', width: "100px"},
  219. {title: '本年度工作截止时间', field: 'quitTime', visible: true, align: 'center', valign: 'middle', width: "100px"},
  220. {title: '人才标签', field: 'talentTypeName', visible: true, align: 'center', valign: 'middle', width: "100px", 'class': 'uitd_showTip'},
  221. {title: '首次来晋行政介绍信时间', field: 'letterTime', visible: true, align: 'center', valign: 'middle', width: "120px"},
  222. /*{title: '操作', field: 'id', visible: true, align: 'center', valign: 'middle', width: "120px",
  223. formatter: function (value, row, index) {
  224. return "<button type='button' onclick='TalentAllowanceInfoDlg.showLog(\"" + row.id + "\")' style='margin-right: 10px' class='btn btn-xs btn-success'>" +
  225. "<i class=\"fa fa-book\"></i>日志" +
  226. "</button>";
  227. }
  228. }*/
  229. ];
  230. } else {
  231. return [
  232. {field: 'selectItem', checkbox: false, visible: false},
  233. {title: '企业名称', field: 'enterpriseName', visible: true, align: 'center', valign: 'middle', width: "120px", 'class': 'uitd_showTip'},
  234. {title: '合同起始时间', field: 'startTime', visible: true, align: 'center', valign: 'middle', width: "120px"},
  235. {title: '合同截止时间', field: 'endTime', visible: true, align: 'center', valign: 'middle', width: "120px", 'class': 'uitd_showTip'},
  236. {title: '入职时间', field: 'entryTime', visible: true, align: 'center', valign: 'middle', width: "100px"},
  237. {title: '本年度工作截止时间', field: 'quitTime', visible: true, align: 'center', valign: 'middle', width: "100px"},
  238. /*{title: '操作', field: 'id', visible: true, align: 'center', valign: 'middle', width: "120px",
  239. formatter: function (value, row, index) {
  240. return "<button type='button' onclick='TalentAllowanceInfoDlg.showLog(\"" + row.id + "\")' style='margin-right: 10px' class='btn btn-xs btn-success'>" +
  241. "<i class=\"fa fa-book\"></i>日志" +
  242. "</button>"
  243. }
  244. }*/
  245. ];
  246. }
  247. }
  248. //初始化项目表的列
  249. TalentAllowanceInfoDlg.initProjectColumns = function () {
  250. return [
  251. {field: 'selectItem', checkbox: false, visible: false},
  252. {title: '核查项目名称', field: 'projectName', visible: true, align: 'center', valign: 'middle', width: "15%", 'class': 'uitd_showTip'},
  253. {title: '详情', field: 'months', visible: true, align: 'center', valign: 'middle', width: "45%", 'class': 'uitd_showTip',
  254. formatter: function (value, row, index) {
  255. var allowanceType = $("#allowanceType").val();
  256. var tmp = [];
  257. if (row.project == 4 && allowanceType == 2) {
  258. var dayArr = value ? value.split(",") : [];
  259. var totalDays = 0;
  260. for (var d = 0; d < dayArr.length; d++) {
  261. var kv = dayArr[d].split("=");
  262. if (kv[0] && kv[1]) {
  263. totalDays += parseInt(kv[1]);
  264. tmp.push(kv[0] + "月(" + kv[1] + "天)");
  265. }
  266. }
  267. tmp.push("共计" + totalDays + "天");
  268. } else {
  269. var monthArr = value ? value.split(",") : [];
  270. for (var d = 0; d < monthArr.length; d++) {
  271. if (monthArr[d]) {
  272. tmp.push(monthArr[d] + "月");
  273. }
  274. }
  275. }
  276. return tmp.join(",");
  277. }
  278. },
  279. {title: '备注', field: 'description', visible: true, align: 'center', valign: 'middle', width: "25%", 'class': 'uitd_showTip'},
  280. {title: '操作', field: 'project', visible: true, align: 'center', valign: 'middle', width: "15%",
  281. formatter: function (value, row, index) {
  282. return "<button type='button' onclick='TalentAllowanceInfoDlg.showLog(\"" + row.id + "\")' style='margin-right: 10px' class='btn btn-xs btn-success'><i class=\"fa fa-book\"></i>日志</button>";
  283. }
  284. }
  285. ];
  286. }
  287. /**
  288. * 初始化附件类别表的列
  289. */
  290. TalentAllowanceInfoDlg.initFileTypeColumn = function () {
  291. return [
  292. {field: 'selectItem', checkbox: false, visible: false},
  293. {title: '名称', field: 'name', visible: true, align: 'center', valign: 'middle', width: "30%", 'class': 'uitd_showTip',
  294. formatter: function (value, row, index) {
  295. if (row.must == 1) {
  296. return '<i class="fa fa-paste"></i><span style="font-weight:bold;color:red;font-size:14px;font-family:宋体"> * </span> ' + value;
  297. }
  298. if (row.must == 2) {
  299. return '<i class="fa fa-paste"></i>' + value;
  300. }
  301. }
  302. },
  303. {title: '模板', field: 'templateUrl', visible: true, align: 'center', valign: 'middle', width: "8%",
  304. formatter: function (value, row, index) {
  305. if (value == null || value == '' || value == 'null') {
  306. return '无';
  307. }
  308. return "<button type='button' onclick=\"Feng.downloadFile('" + row.id + "',3)\" style='margin-right: 10px' class=\"btn btn-xs btn-primary\">" +
  309. "<i class=\"fa fa-download\"></i>下载" +
  310. "</button>";
  311. }
  312. },
  313. {title: '备注', field: 'description', visible: true, align: 'center', valign: 'middle', width: "52%", 'class': 'uitd_showTip'},
  314. ]
  315. };
  316. TalentAllowanceInfoDlg.showLog = function (id) {
  317. layer.open({
  318. type: 1,
  319. title: "日志",
  320. fixed: false,
  321. content: '<table id="' + id + '"></table>',
  322. area: ['80%', '80%'],
  323. maxmin: true,
  324. success: function (layero, index) {
  325. $('#' + id).bootstrapTable({
  326. url: Feng.ctxPath + "/common/api/getJbtCheckLog",
  327. method: 'POST',
  328. contentType: "application/x-www-form-urlencoded; charset=UTF-8",
  329. search: false, // 是否显示表格搜索,此搜索是客户端搜索,不会进服务端
  330. showRefresh: false, // 是否显示刷新按钮
  331. clickToSelect: true, // 是否启用点击选中行
  332. singleSelect: true, // 设置True 将禁止多选
  333. striped: true, // 是否显示行间隔色
  334. pagination: false, // 设置为 true 会在表格底部显示分页条
  335. paginationHAlign: "left",
  336. paginationDetailHAlign: "right",
  337. sidePagination: "server", // 设置在哪里进行分页,可选值为 'client' 或者 'server'
  338. showColumns: false,
  339. queryParams: function (params) {
  340. return {"type": CONFIG.project_jbt, "mainId": $("#id").val(), "typeFileId": id, "active": 1}
  341. },
  342. columns:
  343. [
  344. {title: '步骤', field: 'stepName', visible: true, align: 'center', valign: 'middle', width: "10%",
  345. formatter: function (value, row, index) {
  346. return "" + value;
  347. }
  348. },
  349. {title: '操作人', field: 'createUser', visible: true, align: 'center', valign: 'middle', width: "15%"},
  350. {title: '操作时间', field: 'createTime', visible: true, align: 'center', valign: 'middle', width: "20%"},
  351. {title: '描述', field: 'description', visible: true, align: 'center', valign: 'middle', width: "45%",
  352. formatter: function (value, row, index) {
  353. return '<span data-toggle="tooltip" title="' + value + '">"' + value + '"</span>';
  354. }
  355. }
  356. ]
  357. ,
  358. onPostBody: function () {
  359. $('#' + id + "td.uitd_showTip").bind("mouseover", function () {
  360. var htm = $(this).html();
  361. $(this).webuiPopover({title: '详情', content: htm, trigger: 'hover'}).webuiPopover('show');
  362. });
  363. }
  364. });
  365. }
  366. });
  367. }
  368. //回调
  369. TalentAllowanceInfoDlg.callBack = function (data) {
  370. layer.close(data.obj);
  371. Feng.info(data.msg);
  372. if (data.code == 200) {
  373. var ajax = new $ax(Feng.ctxPath + "/enterprise/talentAllowance/updateSuppleState", function (data) {
  374. if (data.code == 200) {
  375. } else {
  376. }
  377. }, function (data) {
  378. Feng.error("修改失败!" + data.responseJSON.message + "!");
  379. });
  380. ajax.set("id", $("#id").val());
  381. ajax.start();
  382. $("#fileTable").bootstrapTable("refresh", {});
  383. }
  384. }
  385. TalentAllowanceInfoDlg.showAllLog = function () {
  386. var id = $("#id").val();
  387. if (Feng.isNotEmptyStr(id)) {
  388. Feng.getCheckLog("logTable", {"type": CONFIG.project_jbt, "mainId": id, "typeFileId": "", "active": 1})
  389. }
  390. }
  391. TalentAllowanceInfoDlg.calculator = function () {
  392. var id = $("#id").val();
  393. if (!id) {
  394. Feng.error("请先保存再进行计算");
  395. return;
  396. }
  397. var ajax = new $ax(Feng.ctxPath + "/enterprise/talentAllowance/calculator/id/" + id, function (data) {
  398. var message = data.recommendAllowanceMsg.join("<br>");
  399. if (data.recommendAllowanceType != 3) {
  400. message += "<br>试算补贴金额:<span style='color:red;font-weight:bold;'>" + data.finnalMoney + "</span>";
  401. }
  402. Feng.confirm(message, function () {});
  403. }, function (data) {
  404. Feng.error("查询失败!" + data.responseJSON.message + "!");
  405. });
  406. ajax.start();
  407. }
  408. $(function () {
  409. Feng.initValidatorTip("talentAllowanceForm", TalentAllowanceInfoDlg.validateFields);
  410. Feng.addAjaxSelect({
  411. "id": 'name',
  412. "displayCode": "id",
  413. "displayName": "name",
  414. "type": "GET",
  415. "url": Feng.ctxPath + "/enterprise/talent/findTalentByEnterpriseInLibrary?type=1&year=" + $("#year").val()
  416. });
  417. if ($("#type").val() == 2) {
  418. $("#bankNumberSpan,#talentTypeSpan,#introductionModeSpan,#firstInJJTimeSpan").attr("style", "display:none");
  419. }
  420. if ($("#allowanceType").val() == 1) {
  421. //$("#wageDiv").css("display", "block");
  422. }
  423. //批量加载时间控件
  424. $(".date").each(function () {
  425. laydate.render({elem: "#" + $(this).attr("id"), type: 'date', trigger: 'click'});
  426. });
  427. $("select").each(function () {
  428. $(this).val($(this).attr("value"));
  429. });
  430. TalentAllowanceInfoDlg.showAllLog();
  431. });