talentAllowanceInfo_info_supple.js 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610
  1. //回调
  2. TalentAllowanceInfoDlg.callBack = function (data) {
  3. layer.close(data.obj);
  4. Feng.info(data.msg);
  5. if (data.code == 200) {
  6. $("#fileTable").bootstrapTable("refresh", {});
  7. }
  8. }
  9. //全选
  10. TalentAllowanceInfoDlg.checkAll = function (id) {
  11. $("#" + id + " input").each(function () {
  12. $(this).iCheck("check");
  13. })
  14. }
  15. //反选
  16. TalentAllowanceInfoDlg.unCheckAll = function (id) {
  17. $("#" + id + " input").each(function () {
  18. if (this.checked) {
  19. $(this).iCheck("uncheck");
  20. } else {
  21. $(this).iCheck("check");
  22. }
  23. })
  24. }
  25. //初始化工作单位表的列
  26. TalentAllowanceInfoDlg.initContractColumns = function () {
  27. var type = $("#type").val();
  28. var process = $("#process").val();
  29. var companyCode = $("#companyCode").val();
  30. if (type == 1) {
  31. return [
  32. {field: 'selectItem', checkbox: false, visible: false},
  33. {title: '企业名称', field: 'enterpriseName', visible: true, align: 'center', valign: 'middle', width: "100px", 'class': 'uitd_showTip'},
  34. {title: '合同起始时间', field: 'startTime', visible: true, align: 'center', valign: 'middle', width: "90px", 'class': 'uitd_showTip'},
  35. {title: '合同截止时间', field: 'endTime', visible: true, align: 'center', valign: 'middle', width: "90px", 'class': 'uitd_showTip'},
  36. {title: '入职时间', field: 'entryTime', visible: true, align: 'center', valign: 'middle', width: "100px", 'class': 'uitd_showTip'},
  37. {title: '本年度工作截止时间', field: 'quitTime', visible: true, align: 'center', valign: 'middle', width: "100px", 'class': 'uitd_showTip'},
  38. {title: '人才标签', field: 'talentTypeName', visible: true, align: 'center', valign: 'middle', width: "100px", 'class': 'uitd_showTip'},
  39. {title: '首次来晋行政介绍信时间', field: 'letterTime', visible: true, align: 'center', valign: 'middle', width: "120px", 'class': 'uitd_showTip'},
  40. {title: '认定条件证书取得时间', field: 'identifyGetTime', visible: true, align: 'center', valign: 'middle', width: "120px", 'class': 'uitd_showTip'},
  41. {title: '操作', field: 'id', visible: true, align: 'center', valign: 'middle', width: "150px",
  42. formatter: function (value, row, index) {
  43. var html = "";
  44. html = html + "<button type='button' onclick='Feng.showContract(" + $("#talentId").val() + ")' style='margin-right: 10px' class='btn btn-xs btn-info'>" +
  45. "<i class=\"fa fa-edit\"></i>查看" +
  46. "</button>";
  47. html = html + "<button type='button' onclick='TalentAllowanceInfoDlg.showLog(\"" + value + "\")' style='margin-right: 10px' class='btn btn-xs btn-success'>" +
  48. "<i class=\"fa fa-book\"></i>日志" +
  49. "</button>";
  50. return html;
  51. }
  52. }
  53. ];
  54. } else {
  55. return [
  56. {field: 'selectItem', checkbox: false, visible: false},
  57. {title: '企业名称', field: 'enterpriseName', visible: true, align: 'center', valign: 'middle', width: "120px", 'class': 'uitd_showTip'},
  58. {title: '合同起始时间', field: 'startTime', visible: true, align: 'center', valign: 'middle', width: "120px", 'class': 'uitd_showTip'},
  59. {title: '合同截止时间', field: 'endTime', visible: true, align: 'center', valign: 'middle', width: "120px", 'class': 'uitd_showTip'},
  60. {title: '入职时间', field: 'entryTime', visible: true, align: 'center', valign: 'middle', width: "80px"},
  61. {title: '本年度工作截止时间', field: 'quitTime', visible: true, align: 'center', valign: 'middle', width: "80px"},
  62. {title: '操作', field: 'id', visible: true, align: 'center', valign: 'middle', width: "150px",
  63. formatter: function (value, row, index) {
  64. var html = "";
  65. html = html + "<button type='button' onclick='Feng.showContract(" + $("#talentId").val() + ")' style='margin-right: 10px' class='btn btn-xs btn-info'>" +
  66. "<i class=\"fa fa-edit\"></i>查看" +
  67. "</button>";
  68. html = html + "<button type='button' onclick='TalentAllowanceInfoDlg.showLog(\"" + value + "\")' style='margin-right: 10px' class='btn btn-xs btn-success'>" +
  69. "<i class=\"fa fa-book\"></i>日志" +
  70. "</button>";
  71. return html;
  72. }
  73. }
  74. ];
  75. }
  76. }
  77. //初始化项目表的列
  78. TalentAllowanceInfoDlg.initProjectColumns = function (enterpriseId) {
  79. var process = $("#process").val();
  80. return [
  81. {field: 'selectItem', checkbox: false, visible: false},
  82. {title: '核查项目名称', field: 'projectName', visible: true, align: 'center', valign: 'middle', width: "10%", 'class': 'uitd_showTip'},
  83. {title: '详情', field: 'months', visible: true, align: 'center', valign: 'middle', width: "55%", 'class': 'uitd_showTip',
  84. formatter: function (value, row, index) {
  85. var allowanceType = $("#allowanceType").val();
  86. var tmp = [];
  87. if (row.project == 4 && allowanceType == 2) {
  88. var dayArr = value ? value.split(",") : [];
  89. var totalDays = 0;
  90. for (var d = 0; d < dayArr.length; d++) {
  91. var kv = dayArr[d].split("=");
  92. if (kv[0] && kv[1]) {
  93. totalDays += parseInt(kv[1]);
  94. tmp.push(kv[0] + "月(" + kv[1] + "天)");
  95. }
  96. }
  97. tmp.push("共计" + totalDays + "天");
  98. return tmp.join(",");
  99. } else {
  100. var monthArr = value ? value.split(",") : [];
  101. for (var m = 1; m <= 12; m++) {
  102. let mstr = m < 10 ? "0" + m : m;
  103. if (monthArr.indexOf(mstr.toString()) > -1) {
  104. tmp.push("<li class='green'>" + m + "月</li>");
  105. } else {
  106. tmp.push("<li class='gray'>" + m + "月</li>");
  107. }
  108. }
  109. return "<ul class='project-detail'>" + tmp.join("") + "</ul>";
  110. }
  111. }
  112. },
  113. {title: '备注', field: 'description', visible: true, align: 'center', valign: 'middle', width: "25%", 'class': 'uitd_showTip'},
  114. {title: '操作', field: 'project', visible: true, align: 'left', valign: 'middle', width: "10%",
  115. formatter: function (value, row, index) {
  116. var html = "";
  117. if (process == 1) {
  118. var companyCode = $("#companyCode").val();
  119. if (companyCode == CONFIG.COM_RSJ || companyCode == CONFIG.COM_IC) {
  120. if (value == 1) {
  121. html = html + "<button type='button' data-value='" + row.description + "' onclick=\"TalentAllowanceInfoDlg.showEditProjectModal('" + row.project + "','" + row.id + "','" + enterpriseId + "','" + row.months + "','" + row.days + "',this)\" style='margin-left: 5px;' class=\"btn btn-xs btn-danger\">" +
  122. "<i class=\"fa fa-edit\"></i>修改" +
  123. "</button>";
  124. }
  125. }
  126. if ($("#type").val() == 6 && $("#process").val() == 1) {
  127. html = html + "<button type='button' data-value='" + row.description + "' onclick=\"TalentAllowanceInfoDlg.showEditProjectModal('" + row.project + "','" + row.id + "','" + enterpriseId + "','" + row.months + "','" + row.days + "',this)\" style='margin-left: 5px;' class=\"btn btn-xs btn-danger\">" +
  128. "<i class=\"fa fa-edit\"></i>修改" +
  129. "</button>";
  130. }
  131. if ((companyCode == CONFIG.COM_SWJ || companyCode == CONFIG.COM_RSJ) && value == 2) {
  132. html = html + "<button type='button' data-value='" + row.description + "' onclick=\"TalentAllowanceInfoDlg.showEditProjectModal('" + row.project + "','" + row.id + "','" + enterpriseId + "','" + row.months + "','" + row.days + "',this)\" style='margin-left: 5px;' class=\"btn btn-xs btn-danger\">" +
  133. "<i class=\"fa fa-edit\"></i>修改" +
  134. "</button>";
  135. }
  136. }
  137. if (process == 2 && (value == 3 || value == 4 || value == 5 || value == 6 || value == 7)) {
  138. html = html + "<button type='button' data-value='" + row.description + "' onclick=\"TalentAllowanceInfoDlg.showEditProjectModal('" + row.project + "','" + row.id + "','" + enterpriseId + "','" + row.months + "','" + row.days + "',this)\" style='margin-left: 5px;' class=\"btn btn-xs btn-danger\">" +
  139. "<i class=\"fa fa-edit\"></i>修改" +
  140. "</button>";
  141. }
  142. /*if (value == 1 || value == 2) {
  143. html = html + "<button type='button' onclick=\"TalentAllowanceInfoDlg.showFileTable('" + row.project + "')\" style='margin-left: 5px;' class=\"btn btn-xs btn-default\"><i class=\"fa fa-book\"></i>查看附件</button>";
  144. }*/
  145. if (Feng.isNotEmptyStr(row.fileUrl)) {
  146. html = html + "<button type='button' onclick=\"TalentAllowanceInfoDlg.downloadFileByUrl('" + row.fileUrl + "')\" style='margin-left: 5px;' class=\"btn btn-xs btn-success\"><i class=\"fa fa-download\"></i>下载</button>";
  147. }
  148. html = html +
  149. "<button type='button' onclick='TalentAllowanceInfoDlg.showLog(\"" + row.id + "\")' class='btn btn-xs btn-success' style='margin-left: 5px;'>" +
  150. "<i class=\"fa fa-book\"></i>日志" +
  151. "</button>";
  152. return html;
  153. }
  154. }
  155. ];
  156. }
  157. TalentAllowanceInfoDlg.showFileTable = function (project) {
  158. var api = (project == 1) ? CONFIG.jbt_concat : CONFIG.jbt_tax;
  159. var index = layer.open({
  160. type: 1,
  161. title: "附件材料",
  162. shade: 0,
  163. fixed: false,
  164. content: '<ul class="showImgs" style="padding: 0px 5px 0px 5px;"><li style="width: 80%;font-weight: bold;padding-top: 5px;">附件原名</li><li style="width: 10%;font-weight: bold;padding-top: 5px;">预览</li><li style="width: 10%;font-weight: bold;padding-top: 5px;">操作</li></ul>',
  165. area: ['50%', '50%'],
  166. maxmin: true,
  167. btn: ['<i class="fa fa-eraser"></i>&nbsp;&nbsp;关闭'],
  168. success: function (layero, index) {
  169. var ajax = new $ax(Feng.ctxPath + "/commmon/api/getTalentFileByApi?api=" + api + "&mainId=" + $("#id").val(), function (data) {
  170. if (data.code == 500) {
  171. Feng.error(data.msg);
  172. return;
  173. }
  174. var html = "";
  175. var files = data.obj;
  176. for (var key in files) {
  177. var sn = files[key].url.lastIndexOf(".");
  178. var suffix = files[key].url.substring(sn + 1, files[key].url.length);
  179. var imgStr = "";
  180. if (suffix == "pdf" || suffix == "PDF") {
  181. imgStr = "<button type='button' onclick=\"Feng.showPdf('" + files[key].url + "','" + files[key].id + "','" + files[key].orignName + "')\" class=\"btn btn-xs btn-danger\"><i class=\"fa fa-file-pdf-o\" aria-hidden=\"true\"></i></button>";
  182. } else if (suffix == "xlsx" || suffix == "XLSX" || suffix == 'xls' || suffix == 'XLS') {
  183. imgStr = "<button type='button' onclick=\"Feng.showExcel('" + files[key].url + "','" + files[key].id + "','" + files[key].orignName + "')\" class=\"btn btn-xs btn-danger\"><i class=\"fa fa-file-excel-o\" aria-hidden=\"true\"></i></button>";
  184. } else {
  185. imgStr = '<img class=\"imgUrl\" src=\"' + files[key].url + '\" style=\"width:25px;height:25px;\">';
  186. }
  187. html = html + '<li style="display: none">' + files[key].id + '</li>\n' +
  188. '<li style="width: 80%;padding-top: 5px;">' + files[key].orignName + '</li>\n' +
  189. '<li style="width: 10%;">' + imgStr + '</li>\n' +
  190. "<li style='width: 10%;padding-top: 2px;'><button type='button' onclick=\"Feng.downloadFile('" + files[key].id + "',1)\" class=\"btn btn-xs btn-success\"><i class=\"fa fa-download\" aria-hidden=\"true\"></i>下载</button></li>";
  191. }
  192. $(".showImgs").append(html);
  193. $(".showImgs").viewer({
  194. fullscreen: false
  195. });
  196. });
  197. ajax.start();
  198. }
  199. });
  200. }
  201. /**
  202. * 初始化附件类别表的列
  203. */
  204. TalentAllowanceInfoDlg.initFileTypeColumn = function () {
  205. var title = [];
  206. title = [
  207. {field: 'selectItem', checkbox: false, visible: false},
  208. {title: '名称', field: 'name', visible: true, align: 'center', valign: 'middle', width: "52%", 'class': 'uitd_showTip',
  209. formatter: function (value, row, index) {
  210. if (row.must == 1) {
  211. return '<i class="fa fa-paste"></i><span style="font-weight:bold;color:red;font-size:14px;font-family:宋体"> * </span> ' + value;
  212. }
  213. if (row.must == 2) {
  214. return '<i class="fa fa-paste"></i>' + value;
  215. }
  216. }
  217. },
  218. {title: '模板', field: 'templateUrl', visible: true, align: 'center', valign: 'middle', width: "8%",
  219. formatter: function (value, row, index) {
  220. if (value == null || value == '' || value == 'null') {
  221. return '无';
  222. }
  223. return "<button type='button' onclick=\"Feng.downloadFile('" + value + "',3)\" style='margin-right: 10px' class=\"btn btn-xs btn-primary\">" +
  224. "<i class=\"fa fa-download\"></i>下载" +
  225. "</button>";
  226. }
  227. },
  228. {title: '备注', field: 'description', visible: true, align: 'center', valign: 'middle', width: "40%", 'class': 'uitd_showTip'},
  229. ]
  230. if ($("#type").val() == 6 && $("#process").val() == 1) {
  231. title.push({title: '操作', field: 'id', visible: true, align: 'center', valign: 'middle', width: "10%",
  232. formatter: function (value, row, index) {
  233. var files = $("#files").val();
  234. var checkState = $("#checkState").val();
  235. var type = $("#type").val();
  236. return "<button type='button' onclick=\"TalentAllowanceInfoDlg.checkFile(this,'" + value + "','" + null + "')\" style='margin-right: 10px' class=\"btn btn-xs btn-info\">" +
  237. "<i class=\"fa fa-upload\"></i>添加" +
  238. "</button>";
  239. }
  240. })
  241. }
  242. return title;
  243. };
  244. //选择附件并显示附件名
  245. TalentAllowanceInfoDlg.checkFile = function (content, fileTypeId, fileId) {
  246. $("#upload_file ").unbind("change");
  247. $("#upload_file ").change(function () {
  248. TalentAllowanceInfoDlg.upload(fileTypeId, fileId);
  249. });
  250. $('#upload_file').val("");
  251. $('#upload_file').click()
  252. }
  253. //上传附件
  254. TalentAllowanceInfoDlg.upload = function (fileTypeId, fileId) {
  255. var id = $("#id").val();
  256. if (fileId != null && fileId != 'null') {
  257. $("#fileId").val(fileId)
  258. } else {
  259. $("#fileId").val("");
  260. }
  261. $("#mainId").val(id);
  262. $("#fileTypeId").val(fileTypeId);
  263. var index = layer.load(0, {shade: false, time: 0});
  264. $("#index").val(index);
  265. $("#uploadForm").submit();
  266. }
  267. //删除附件
  268. TalentAllowanceInfoDlg.deleteFile = function (id) {
  269. var operation = function () {
  270. var ajax = new $ax(Feng.ctxPath + "/common/api/deleteFile", function (data) {
  271. if (data.code = 200) {
  272. Feng.success(data.msg);
  273. $("#fileTable").bootstrapTable("refresh", {});
  274. } else {
  275. Feng.error(data.msg);
  276. }
  277. }, function (data) {
  278. Feng.error("删除失败!" + data.responseJSON.message + "!");
  279. });
  280. ajax.set("id", id);
  281. ajax.set("type", CONFIG.project_jbt);
  282. ajax.start();
  283. }
  284. Feng.confirm("删除后无法恢复,确认删除吗?", operation);
  285. }
  286. TalentAllowanceInfoDlg.initArrangeColumn = function () {
  287. return [
  288. {field: 'selectItem', checkbox: false, visible: false},
  289. {title: '人才层次', field: 'talentArrangeName', visible: true, align: 'center', valign: 'middle', width: "100px"},
  290. {title: '认定条件', field: 'identifyConditionText', visible: true, align: 'center', valign: 'middle', width: "120px", 'class': 'uitd_showTip'},
  291. {title: '人才证书发证日期', field: 'startTime', visible: true, align: 'center', valign: 'middle', width: "100px"},
  292. {title: '人才证书有效期', field: 'endTime', visible: true, align: 'center', valign: 'middle', width: "100px"},
  293. {title: '忽略其他条件可享受月份', field: 'prepareMonths', visible: true, align: 'center', valign: 'middle', width: "150px", 'class': 'uitd_showTip'},
  294. {title: '综合可享受月份', field: 'months', visible: true, align: 'center', valign: 'middle', width: "150px", 'class': 'uitd_showTip'},
  295. {title: '备注', field: 'description', visible: true, align: 'center', valign: 'middle', width: "150px", 'class': 'uitd_showTip'},
  296. ]
  297. }
  298. TalentAllowanceInfoDlg.downloadFileByUrl = function (url) {
  299. window.location.href = Feng.ctxPath + "/common/api/downloadByUrl?url=" + url;
  300. }
  301. TalentAllowanceInfoDlg.showLog = function (id) {
  302. layer.open({
  303. type: 1,
  304. title: "日志",
  305. fixed: false,
  306. content: '<table id="' + id + '"></table>',
  307. area: ['80%', '80%'],
  308. maxmin: true,
  309. success: function (layero, index) {
  310. $('#' + id).bootstrapTable({
  311. url: Feng.ctxPath + "/common/api/getJbtCheckLog",
  312. method: 'POST',
  313. contentType: "application/x-www-form-urlencoded; charset=UTF-8",
  314. search: false, // 是否显示表格搜索,此搜索是客户端搜索,不会进服务端
  315. showRefresh: false, // 是否显示刷新按钮
  316. clickToSelect: true, // 是否启用点击选中行
  317. singleSelect: true, // 设置True 将禁止多选
  318. striped: true, // 是否显示行间隔色
  319. pagination: false, // 设置为 true 会在表格底部显示分页条
  320. paginationHAlign: "left",
  321. paginationDetailHAlign: "right",
  322. sidePagination: "server", // 设置在哪里进行分页,可选值为 'client' 或者 'server'
  323. showColumns: false,
  324. queryParams: function (params) {
  325. return {"type": CONFIG.project_jbt, "mainId": $("#id").val(), "typeFileId": id, "active": 1}
  326. },
  327. columns:
  328. [
  329. {title: '步骤', field: 'stepName', visible: true, align: 'center', valign: 'middle', width: "10%",
  330. formatter: function (value, row, index) {
  331. return "" + value;
  332. }
  333. },
  334. {title: '操作人', field: 'createUser', visible: true, align: 'center', valign: 'middle', width: "15%"},
  335. {title: '操作时间', field: 'createTime', visible: true, align: 'center', valign: 'middle', width: "20%"},
  336. {title: '描述', field: 'description', visible: true, align: 'center', valign: 'middle', width: "45%",
  337. formatter: function (value, row, index) {
  338. return '<span data-toggle="tooltip" title="' + value + '">"' + value + '"</span>';
  339. }
  340. }
  341. ]
  342. ,
  343. onPostBody: function () {
  344. $('#' + id + "td.uitd_showTip").bind("mouseover", function () {
  345. var htm = $(this).html();
  346. $(this).webuiPopover({title: '详情', content: htm, trigger: 'hover'}).webuiPopover('show');
  347. });
  348. }
  349. });
  350. }
  351. });
  352. }
  353. //初始化附件类别表单
  354. TalentAllowanceInfoDlg.initFileTable = function () {
  355. TalentAllowanceInfoDlg.initContract();
  356. // Feng.showMiniFileModal(CONFIG.project_jbt,$("#type").val(),$("#id").val());
  357. var queryData = {};
  358. queryData["mainId"] = $("#id").val();
  359. queryData['project'] = CONFIG.project_jbt;
  360. queryData['type'] = $("#type").val();
  361. queryData['allowanceType'] = $("#allowanceType").val();
  362. $("#fileTable").bootstrapTable({
  363. url: Feng.ctxPath + "/common/api/findCommonFileType",
  364. method: 'POST',
  365. contentType: "application/x-www-form-urlencoded; charset=UTF-8",
  366. search: false, // 是否显示表格搜索,此搜索是客户端搜索,不会进服务端
  367. showRefresh: false, // 是否显示刷新按钮
  368. clickToSelect: true, // 是否启用点击选中行
  369. singleSelect: true, // 设置True 将禁止多选
  370. striped: true, // 是否显示行间隔色
  371. escape: true,
  372. pagination: false, // 设置为 true 会在表格底部显示分页条
  373. paginationHAlign: "left",
  374. paginationDetailHAlign: "right",
  375. sidePagination: "server", // 设置在哪里进行分页,可选值为 'client' 或者 'server'
  376. showColumns: false,
  377. detailView: true, //是否显示父子表
  378. pageList: [10, 30, 50],
  379. queryParams: function (params) {
  380. return $.extend(queryData, params)
  381. },
  382. rowStyle: function (row, index) {
  383. return {classes: "info"};
  384. },
  385. columns: TalentAllowanceInfoDlg.initFileTypeColumn(),
  386. onPostBody: function () {
  387. $("td.uitd_showTip").bind("mouseover", function () {
  388. var htm = $(this).html();
  389. $(this).webuiPopover({title: '详情', content: htm, trigger: 'hover'}).webuiPopover('show');
  390. });
  391. },
  392. onLoadSuccess: function (data) {
  393. $("#fileTable").bootstrapTable('expandAllRows');
  394. },
  395. onExpandRow: function (index, row, $detail) {
  396. var ajax = new $ax(Feng.ctxPath + "/common/api/listTalentFile", function (data) {
  397. if (data == null || data.length == 0) {
  398. return;
  399. }
  400. var html = '<ul class="imgs"><li style="width: 70%;font-weight: bold;padding-top: 5px;">附件原名</li><li style="width: 10%;font-weight: bold;padding-top: 5px;">预览</li><li style="width: 20%;font-weight: bold;padding-top: 5px;">操作</li>';
  401. for (var key in data) {
  402. var sn = data[key].url.lastIndexOf(".");
  403. var suffix = data[key].url.substring(sn + 1, data[key].url.length);
  404. var imgStr = "";
  405. if (suffix == "pdf" || suffix == "PDF") {
  406. 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>";
  407. } else if (suffix == "xlsx" || suffix == "XLSX" || suffix == 'xls' || suffix == 'XLS') {
  408. 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>";
  409. } else {
  410. imgStr = '<img class=\"imgUrl\" src=\"' + data[key].url + '\" style=\"width:25px;height:25px;\">';
  411. }
  412. html = html + '<li style="display: none">' + data[key].id + '</li>\n' +
  413. '<li style="width: 70%;padding-top: 5px;">' + data[key].orignName + '</li>\n' +
  414. '<li style="width: 10%;">' + imgStr + '</li>\n' +
  415. "<li style='width: 20%;padding-top: 2px;'>\n" + ($("#type").val() == 6 && $("#process").val() == 1 ? "<button type=\'button\' onclick=\"TalentAllowanceInfoDlg.checkFile(this,'" + row.id + "','" + data[key].id + "')\" style=\'margin-left: 5px\' class=\"btn btn-xs btn-success\">" +
  416. "<i class=\"fa fa-paste\"></i>修改" +
  417. "</button>" +
  418. "<button type='button' onclick=\"TalentAllowanceInfoDlg.deleteFile('" + data[key].id + "','" + row.fState + "')\" style=\'margin-left: 5px\' class=\"btn btn-xs btn-danger\">" +
  419. "<i class=\"fa fa-times\"></i>删除" +
  420. "</button>" : "") +
  421. "<button type='button' onclick=\"Feng.downloadFile('" + data[key].id + "',1)\" style=\'margin-left: 5px\' class=\"btn btn-xs btn-success\"><i class=\"fa fa-download\" aria-hidden=\"true\"></i>下载</button></li>";
  422. }
  423. html = html + '</ul>';
  424. $detail.html(html);
  425. $(".imgs").viewer({
  426. // toolbar:false,
  427. fullscreen: false
  428. });
  429. }, function (data) {
  430. Feng.error("查询失败!" + data.responseJSON.message + "!");
  431. });
  432. var queryData = {};
  433. queryData["mainId"] = $("#id").val();
  434. queryData["fileTypeId"] = row.id;
  435. ajax.set(queryData);
  436. ajax.start();
  437. }
  438. });
  439. }
  440. //初始化通用附件
  441. TalentAllowanceInfoDlg.initCommonFileTable = function () {
  442. var queryData = {};
  443. queryData.id = $("#id").val();
  444. $("#commonFileTable").bootstrapTable({
  445. url: Feng.ctxPath + "/common/api/listTalentAllowanceCommonFile",
  446. method: 'POST',
  447. contentType: "application/x-www-form-urlencoded; charset=UTF-8",
  448. search: false, // 是否显示表格搜索,此搜索是客户端搜索,不会进服务端
  449. showRefresh: false, // 是否显示刷新按钮
  450. clickToSelect: true, // 是否启用点击选中行
  451. singleSelect: true, // 设置True 将禁止多选
  452. striped: true, // 是否显示行间隔色
  453. pagination: false, // 设置为 true 会在表格底部显示分页条
  454. paginationHAlign: "left",
  455. paginationDetailHAlign: "right",
  456. sidePagination: "server", // 设置在哪里进行分页,可选值为 'client' 或者 'server'
  457. showColumns: false,
  458. queryParams: function (params) {
  459. return $.extend(queryData, params)
  460. },
  461. rowStyle: function (row, index) {
  462. return {css: {"word-break": "break-word", "white-space": "inherit"}}
  463. },
  464. columns: [
  465. {title: '附件原名', field: 'originalName', visible: true, align: 'center', valign: 'middle', 'class': 'uitd_showTip', width: '60%', formatter: function (value, row, index) {
  466. return value;
  467. }},
  468. {title: '附件类型', field: 'fileTypeName', visible: true, align: 'center', valign: 'middle', 'class': 'uitd_showTip', width: '20%', formatter: function (value, row, index) {
  469. return value;
  470. }},
  471. {title: '预览', field: 'url', visible: true, align: 'center', valign: 'middle', width: "20%",
  472. formatter: function (value, row, index) {
  473. var sn = value.lastIndexOf(".");
  474. var suffix = value.substring(sn + 1, value.length);
  475. var imgStr = "";
  476. if (suffix == "pdf" || suffix == "PDF") {
  477. 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>";
  478. } else if (suffix == "xlsx" || suffix == "XLSX" || suffix == 'xls' || suffix == 'XLS') {
  479. 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>";
  480. } else {
  481. imgStr = '<img class=\"cImgUrl\" src=\"' + value + '\" style=\"width:25px;height:25px;\">';
  482. }
  483. return imgStr;
  484. }
  485. }
  486. ],
  487. onPostBody: function () {
  488. $("td.uitd_showTip").bind("mouseover", function () {
  489. var htm = $(this).html();
  490. $(this).webuiPopover({title: '详情', content: htm, trigger: 'hover'}).webuiPopover('show');
  491. });
  492. $(".cImgUrl").viewer({fullscreen: false});
  493. }
  494. });
  495. }
  496. /**
  497. *
  498. */
  499. TalentAllowanceInfoDlg.createCheckHtml = function () {
  500. var type = $("#type").val();
  501. var process = $("#process").val();
  502. var companyCode = $("#companyCode").val();
  503. var html = "";
  504. switch (process) {
  505. case '1':
  506. html =
  507. '<form id="checkForm">\n' +
  508. '<div class="form-group" style="margin: 10px;">\n' +
  509. '<label for="checkState" class="control-label">审核状态</label>\n' +
  510. '<select class="form-control" id="checkStateModal" onchange="TalentAllowanceInfoDlg.toggleField()">\n' +
  511. '<option value=""></option>\n' +
  512. '<option value="3">审核通过</option>\n' +
  513. '<option value="2">审核驳回</option>\n' +
  514. '<option value="-1">审核不通过</option>\n' +
  515. '</select>\n' +
  516. '</div>\n' +
  517. '<div class="form-group" style="margin: 10px;">\n' +
  518. '<label for="checkMsg" class="control-label">审核意见</label>\n' +
  519. '<textarea class="form-control" id="checkMsg" rows="5"></textarea>\n' +
  520. '</div>\n' +
  521. '<div class="form-group" id="field" style="display: none;margin: 10px">\n';
  522. if ($("#type").val() == 6 && ($("#postType option").length > 0 || $("#institution option").length > 0)) {
  523. html = html +
  524. '<label for="field_concat" class="control-label">可修改合同时间</label>\n' +
  525. '<div id="field_concat">\n' +
  526. '</div>\n' +
  527. '<label for="field_project" class="control-label">可修改字段</label>\n' +
  528. '<div id="field_field">\n' +
  529. '<ul><li style="width: 100%"><input type="checkbox" value="allowanceType"><span>津补贴类型</span></li>';
  530. if ($("#postType option").length > 0) {
  531. html += '<li style="width: 100%"><input type="checkbox" value="postType"><span>岗位类型</span></li>';
  532. }
  533. if ($("#institution option").length > 0) {
  534. html += '<li style="width: 100%"><input type="checkbox" value="institution"><span>所属编制</span></li>';
  535. }
  536. html += '</ul></div>';
  537. } else {
  538. html = html +
  539. '<label for="field_concat" class="control-label">可修改合同时间</label>\n' +
  540. '<div id="field_concat">\n' +
  541. '</div>\n' +
  542. '<label for="field_project" class="control-label">可修改字段</label>\n' +
  543. '<div id="field_field">\n' +
  544. '<ul><li style="width: 100%"><input type="checkbox" value="allowanceType"><span>津补贴类型</span></li></ul>\n' +
  545. '<!--<li style="width: 100%"><input type="checkbox" value="wage"><span>上一年度年薪(元)</span></li>--></ul>\n' +
  546. '</div>\n';
  547. }
  548. html = html +
  549. '<label for="field_project" class="control-label">可修改项目</label>\n' +
  550. '<div id="field_project">\n' +
  551. '</div>\n' +
  552. '<label for="field_file" class="control-label">可修改附件</label>\n' +
  553. '<div id="field_file">\n' +
  554. '</div>\n' +
  555. '<div class="form-group" style="text-align: center">\n' +
  556. '<button type="button" class="btn btn-primary" onclick="TalentAllowanceInfoDlg.checkAll(\'field\')">全选</button>\n' +
  557. '<button type="button" class="btn btn-success" onclick="TalentAllowanceInfoDlg.unCheckAll(\'field\')">反选</button>\n' +
  558. '</div>\n' +
  559. '</div>\n' +
  560. '</form>';
  561. break;
  562. case '3':
  563. html =
  564. '<form id="checkForm">\n' +
  565. '<div class="form-group" style="margin: 10px;">\n' +
  566. '<label for="checkState" class="control-label">审核状态</label>\n' +
  567. '<select class="form-control" id="checkStateModal" onchange="TalentAllowanceInfoDlg.toggleField()">\n' +
  568. '<option value=""></option>\n' +
  569. '<option value="3">审核通过</option>\n' +
  570. '<option value="2">审核驳回</option>\n' +
  571. '<option value="-1">审核不通过</option>\n' +
  572. '</select>\n' +
  573. '</div>\n' +
  574. '<div class="form-group" style="margin: 10px;">\n' +
  575. '<label for="checkMsg" class="control-label">审核意见</label>\n' +
  576. '<textarea class="form-control" id="checkMsg" rows="5"></textarea>\n' +
  577. '</div>\n' +
  578. '</form>';
  579. break;
  580. }
  581. return html;
  582. }
  583. TalentAllowanceInfoDlg.processChange = function (content) {
  584. var process = $(content).val();
  585. var checkStateModal = $("#checkStateModal").val();
  586. if (process == 1 && checkStateModal == 2) {
  587. $("#toDepDiv").css("display", "block");
  588. $('#toDep').chosen({width: '100%', placeholder_text_multiple: '请选择驳回单位'});
  589. } else {
  590. $("#toDepDiv").css("display", "none");
  591. }
  592. }