profile_cert.js 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417
  1. /**
  2. * 账号相关js
  3. *
  4. * @author CaiAoLin
  5. * @date 2018/1/26
  6. * @version
  7. */
  8. $(document).ready(function() {
  9. autoFlashHeight();
  10. $('#addCert').click(function() {
  11. postData('/profile/cert/save', { type: 'add_cert' }, function(result) {
  12. console.log(result);
  13. const html = insertCertHtml(result.total, result.data);
  14. $('#certs').prepend(html);
  15. });
  16. });
  17. $('body').on('click', '#certs .add-jx-btn', function() {
  18. const _self = $(this);
  19. postData('/profile/cert/save', { type: 'add_jx', id: $(this).parents('.one-cert').data('cid') }, function(result) {
  20. console.log(result);
  21. const html = insertJxHtml(result.data, result.jxData);
  22. _self.parents('.pull-right').siblings('.all-jx').prepend(html);
  23. console.log(_self.parents('.pull-right').siblings('.all-jx').children('.one-jx').eq(0).find('.jx-date'));
  24. _self.parents('.pull-right').siblings('.all-jx').children('.one-jx').eq(0).find('.jx-date').datepicker({
  25. onShow: function (res) {
  26. res.$el.attr('readOnly', true);
  27. },
  28. onHide: function (res, animationCompleted) {
  29. if(animationCompleted) {
  30. res.$el.attr('readOnly', false);
  31. const val = res.$el.val();
  32. const oldVal = res.$el.attr('data-old-date') || '';
  33. // 日期格式判断
  34. if (val !== '') {
  35. const valArr = val.split(' ~ ');
  36. for (const v of valArr) {
  37. if (!(isNaN(v) && !isNaN(Date.parse(v)))) {
  38. toastr.error('日期格式有误!');
  39. res.$el.val(oldVal);
  40. if (oldVal === '') {
  41. res.clear();
  42. } else {
  43. res.selectDate(new Date(oldVal));
  44. }
  45. return;
  46. }
  47. }
  48. } else if(val !== oldVal) {
  49. const data = {
  50. id: res.$el.parents('.one-cert').data('cid'),
  51. jxid: res.$el.parents('.one-jx').data('jxid'),
  52. key: 'date',
  53. value: val,
  54. };
  55. updateJxDataFun(data);
  56. res.$el.attr('data-old-date', val);
  57. }
  58. }
  59. }
  60. });
  61. });
  62. });
  63. $('body').on('change', '#certs select', function() {
  64. const value = parseInt($(this).val());
  65. const key = $(this).data('type');
  66. const update_data = {
  67. id: $(this).parents('.one-cert').data('cid'),
  68. key,
  69. value,
  70. };
  71. if (key === 'type') {
  72. let html = '';
  73. if (value === 0) {
  74. update_data.other = {
  75. key: 'name',
  76. value: null,
  77. };
  78. html = '<option value="0">请选择</option>';
  79. } else {
  80. update_data.other = {
  81. key: 'name',
  82. value: certSourceConst[showCol4ObjArray(certTypeConst, value, 'value', 'source')][0].value,
  83. };
  84. html = changeSourceHtml(certSourceConst[showCol4ObjArray(certTypeConst, value, 'value', 'source')]);
  85. }
  86. $(this).parents('.one-cert-msg').find('.select-cert-name').html(html);
  87. }
  88. console.log(update_data);
  89. postData('/profile/cert/save', { type: 'update_cert', update_data }, function(result) {
  90. console.log(result);
  91. });
  92. });
  93. function changeSourceHtml(source = []) {
  94. let html = '';
  95. for (const s of source) {
  96. html += `<option value="${s.value}">${s.name}</option>`;
  97. }
  98. return html;
  99. }
  100. $('body').on('change', '#certs .one-cert-msg input[type="text"]', function() {
  101. const value = $(this).val();
  102. const key = $(this).data('type');
  103. const update_data = {
  104. id: $(this).parents('.one-cert').data('cid'),
  105. key,
  106. value,
  107. };
  108. console.log(update_data);
  109. postData('/profile/cert/save', { type: 'update_cert', update_data }, function(result) {
  110. console.log(result);
  111. });
  112. });
  113. $('body').on('change', '#certs .one-jx input[type="text"]', function() {
  114. const value = $(this).val();
  115. const key = $(this).data('type');
  116. const update_data = {
  117. id: $(this).parents('.one-cert').data('cid'),
  118. jxid: $(this).parents('.one-jx').data('jxid'),
  119. key,
  120. value,
  121. };
  122. console.log(update_data);
  123. updateJxDataFun(update_data);
  124. });
  125. // 设置默认值
  126. $('.jx-date').each(function() {
  127. const defaultValue = $(this).val(); // 获取当前元素的 value 属性作为默认值
  128. if (defaultValue) {
  129. // 初始化日期选择器,并设置默认值
  130. $(this).datepicker().data('datepicker').selectDate(new Date(defaultValue));
  131. }
  132. });
  133. $('body .jx-date').datepicker({
  134. onShow: function (res) {
  135. res.$el.attr('readOnly', true);
  136. },
  137. onHide: function (res, animationCompleted) {
  138. if(animationCompleted) {
  139. res.$el.attr('readOnly', false);
  140. const val = res.$el.val();
  141. const oldVal = res.$el.attr('data-old-date') || '';
  142. // 日期格式判断
  143. if (val !== '') {
  144. const valArr = val.split(' ~ ');
  145. for (const v of valArr) {
  146. if (!(isNaN(v) && !isNaN(Date.parse(v)))) {
  147. toastr.error('日期格式有误!');
  148. res.$el.val(oldVal);
  149. if (oldVal === '') {
  150. res.clear();
  151. } else {
  152. res.selectDate(new Date(oldVal));
  153. }
  154. return;
  155. }
  156. }
  157. } else if(val !== oldVal) {
  158. const data = {
  159. id: res.$el.parents('.one-cert').data('cid'),
  160. jxid: res.$el.parents('.one-jx').data('jxid'),
  161. key: 'date',
  162. value: val,
  163. };
  164. updateJxDataFun(data);
  165. res.$el.attr('data-old-date', val);
  166. }
  167. }
  168. }
  169. });
  170. $('body').on('click', '#certs .del-cert-btn', function() {
  171. $('#delete-cert-cid').val($(this).attr('data-cid'));
  172. $('#delete-cert-jxid').val($(this).attr('data-jxid'));
  173. if ($(this).attr('data-filename')) {
  174. console.log($(this).attr('data-filename'), $(this).attr('data-jxid'));
  175. const txt = $(this).attr('data-jxid') ? '培训证明:' : '证书附件:';
  176. $('#delete-cert-title').text(txt + $(this).attr('data-filename'));
  177. $('#delete-cert-type').val('file');
  178. } else {
  179. $('#delete-cert-title').text($(this).parents('.modal-header').find('b').text());
  180. $('#delete-cert-type').val('cert');
  181. }
  182. });
  183. $('#delete-cert-btn').click(function() {
  184. const data = {
  185. id: $('#delete-cert-cid').val(),
  186. jxid: $('#delete-cert-jxid').val(),
  187. type: $('#delete-cert-type').val(),
  188. };
  189. console.log(data);
  190. const _self = $(this);
  191. postData('/profile/cert/save', { type: 'del_cert', delete_data: data }, function(result) {
  192. _self.parents('.modal').modal('hide');
  193. if (data.type === 'file') {
  194. if (data.jxid) {
  195. $(`.one-cert[data-cid="${data.id}"] .one-jx[data-jxid="${data.jxid}"]`).find('.file-show').html('<input type="file" class="jx-file-upload">');
  196. } else {
  197. $(`.one-cert[data-cid="${data.id}"]`).find('.one-cert-msg').find('.file-show').html('<input type="file" class="cert-file-upload">');
  198. }
  199. } else {
  200. if (data.jxid) {
  201. $(`.one-cert[data-cid="${data.id}"] .one-jx[data-jxid="${data.jxid}"]`).remove();
  202. // 教育信息重新排序
  203. for (let i = 0; i < $(`.one-cert[data-cid="${data.id}"] .one-jx`).length; i++) {
  204. $(`.one-cert[data-cid="${data.id}"] .one-jx`).eq(i).find('.jx-num').text($(`.one-cert[data-cid="${data.id}"] .one-jx`).length - i);
  205. }
  206. } else {
  207. $(`.one-cert[data-cid="${data.id}"]`).remove();
  208. // 证书信息重新排序
  209. for (let i = 0; i < $(`#certs .one-cert`).length; i++) {
  210. $(`#certs .one-cert`).eq(i).find('.cert-num').text($(`#certs .one-cert`).length - i);
  211. }
  212. }
  213. }
  214. });
  215. });
  216. // 上传证书附件
  217. $('body').on('change', '#certs .cert-file-upload', function () {
  218. const file = this.files[0];
  219. const formData = new FormData();
  220. if (file === undefined) {
  221. toastr.error('未选择上传文件!');
  222. $(this).val('');
  223. return false;
  224. }
  225. const ext = file.name.toLowerCase().split('.').splice(-1)[0];
  226. const imgStr = /(jpg|jpeg|png|bmp|BMP|JPG|PNG|JPEG|pdf|PDF)$/;
  227. if (!imgStr.test(ext)) {
  228. toastr.error('请上传正确的图片或pdf格式文件');
  229. $(this).val('');
  230. return
  231. }
  232. const filesize = file.size;
  233. if (filesize > 30 * 1024 * 1024) {
  234. toastr.error('上传的文件大小不能超过30MB!');
  235. $(this).val('');
  236. return false;
  237. }
  238. const id = $(this).parents('.one-cert').data('cid');
  239. formData.append('type', 'upload_cert');
  240. formData.append('id', id);
  241. formData.append('file', file);
  242. console.log(formData);
  243. $(this).val('');
  244. const _self = $(this).parents('.file-show');
  245. postDataWithFile('/profile/cert/upload', formData, function (result) {
  246. _self.html(`<div class="col-form-label">
  247. <a href="${fujianOssPath + result.file_path}" target="_blank">${result.file_name}</a> &nbsp;<a href="#del-cert" data-cid="${id}" data-jxid="" data-filename="${result.file_name}" data-toggle="modal" data-target="#del-cert" class="del-cert-btn text-danger">删除</a>
  248. </div>`);
  249. });
  250. });
  251. // 上传证书附件
  252. $('body').on('change', '#certs .jx-file-upload', function () {
  253. const file = this.files[0];
  254. const formData = new FormData();
  255. if (file === undefined) {
  256. toastr.error('未选择上传文件!');
  257. $(this).val('');
  258. return false;
  259. }
  260. const ext = file.name.toLowerCase().split('.').splice(-1)[0];
  261. const imgStr = /(jpg|jpeg|png|bmp|BMP|JPG|PNG|JPEG|pdf|PDF)$/;
  262. if (!imgStr.test(ext)) {
  263. toastr.error('请上传正确的图片或pdf格式文件');
  264. $(this).val('');
  265. return
  266. }
  267. const filesize = file.size;
  268. if (filesize > 30 * 1024 * 1024) {
  269. toastr.error('上传的文件大小不能超过30MB!');
  270. $(this).val('');
  271. return false;
  272. }
  273. const id = $(this).parents('.one-cert').data('cid');
  274. const jxid = $(this).parents('.one-jx').data('jxid');
  275. formData.append('type', 'upload_jx');
  276. formData.append('id', id);
  277. formData.append('jxid', jxid);
  278. formData.append('file', file);
  279. console.log(formData);
  280. $(this).val('');
  281. const _self = $(this).parents('.file-show');
  282. postDataWithFile('/profile/cert/upload', formData, function (result) {
  283. _self.html(`<div class="col-form-label">
  284. <a href="${fujianOssPath + result.file_path}" target="_blank">${result.file_name}</a> &nbsp;<a href="#del-cert" data-cid="${id}" data-jxid="${jxid}" data-filename="${result.file_name}" data-toggle="modal" data-target="#del-cert" class="del-cert-btn text-danger">删除</a>
  285. </div>`);
  286. });
  287. })
  288. function updateJxDataFun(data) {
  289. console.log(data);
  290. postData('/profile/cert/save', { type: 'update_jx', update_data: data }, function(result) {
  291. // console.log(result);
  292. });
  293. }
  294. function insertJxHtml(data, jxdata) {
  295. const html = `
  296. <div class="one-jx" data-jxid="${jxdata.id}">
  297. <div class="card mt-3">
  298. <div class="modal-header">
  299. <b>继续教育<span class="jx-num">${data.edu_json.length}</span></b>
  300. <div class="pull-right">
  301. <a href="#del-cert" data-cid="${data.id}" data-jxid="${jxdata.id}" data-toggle="modal" data-target="#del-cert" class="del-cert-btn text-danger">删除</a>
  302. </div>
  303. </div>
  304. <div class="card-body">
  305. <div class="form-group row">
  306. <label for="uname" class="ml-3 col-form-label">培训时间:</label>
  307. <div class="col-sm-10">
  308. <input data-language="zh" data-old-date="${jxdata.date}" data-type="date" placeholder="请选择时间" type="text" data-range="true" data-multiple-dates-separator=" ~ " class="jx-date datepicker-here form-control form-control-sm" value="${jxdata.date ? jxdata.date : ''}">
  309. </div>
  310. </div>
  311. <div class="form-group row">
  312. <label for="uname" class="ml-3 col-form-label">培训单位:</label>
  313. <div class="col-sm-10">
  314. <input type="text" class="form-control form-control-sm" data-type="unit" value="${jxdata.unit ? jxdata.unit : ''}">
  315. </div>
  316. </div>
  317. <div class="form-group row">
  318. <label for="uname" class="ml-3 col-form-label">培训证明:</label>
  319. <div class="col-sm-10 file-show">
  320. <input type="file" class="jx-file-upload">
  321. </div>
  322. </div>
  323. </div>
  324. </div>
  325. </div>`;
  326. return html;
  327. }
  328. function insertCertHtml(i, data) {
  329. let typeHtml = ``;
  330. for (const r of certTypeConst) {
  331. typeHtml += `<option value="${r.value}">${r.name}</option>`;
  332. }
  333. const html = `<div class="col-6 mt-3 one-cert" data-cid="${data.id}">
  334. <div class="card">
  335. <div class="modal-header">
  336. <b>证书信息<span class="cert-num">${i}</span></b>
  337. <div class="pull-right">
  338. <a href="#del-cert" data-cid="${data.id}" data-jxid="" data-toggle="modal" data-target="#del-cert" class="del-cert-btn text-danger">删除</a>
  339. </div>
  340. </div>
  341. <div class="card-body">
  342. <b>持证情况:</b>
  343. <div class="m-3 one-cert-msg">
  344. <div class="form-group row">
  345. <label for="uname" class="ml-3 col-form-label">证件名称:</label>
  346. <div class="row col-sm-10 pr-0">
  347. <div class="col-6 pr-0">
  348. <select class="form-control form-control-sm select-cert-type" data-type="type">
  349. <option value="0">请选择</option>
  350. ${typeHtml}
  351. </select>
  352. </div>
  353. <div class="col-6 pr-0">
  354. <select class="form-control form-control-sm select-cert-name" data-type="name">
  355. <option value="0">请选择</option>
  356. </select>
  357. </div>
  358. </div>
  359. </div>
  360. <div class="form-group row">
  361. <label for="uname" class="ml-3 col-form-label">证件编号:</label>
  362. <div class="col-sm-10">
  363. <input type="text" class="form-control form-control-sm" data-type="code" value="${data.code ? data.code : ''}">
  364. </div>
  365. </div>
  366. <div class="form-group row">
  367. <label for="uname" class="ml-3 col-form-label">注册单位:</label>
  368. <div class="col-sm-10">
  369. <input type="text" class="form-control form-control-sm" data-type="reg_unit" value="${data.reg_unit ? data.reg_unit : ''}">
  370. </div>
  371. </div>
  372. <div class="form-group row">
  373. <label for="uname" class="ml-3 col-form-label">技术职称:</label>
  374. <div class="col-sm-10">
  375. <input type="text" class="form-control form-control-sm" data-type="job_title" value="${data.job_title ? data.job_title : ''}">
  376. </div>
  377. </div>
  378. <div class="form-group row">
  379. <label for="uname" class="ml-3 col-form-label">证书附件:</label>
  380. <div class="col-sm-10 file-show">
  381. <input type="file" class="cert-file-upload">
  382. </div>
  383. </div>
  384. </div>
  385. <div>
  386. <b>继续教育情况:</b>
  387. <div class="pull-right">
  388. <a href="javascript:void(0);" class="add-jx-btn">+添加</a>
  389. </div>
  390. <div class="all-jx">
  391. </div>
  392. </div>
  393. </div>
  394. </div>
  395. </div>`;
  396. return html;
  397. }
  398. function showCol4ObjArray(arr, col, key, showKey) {
  399. if (!col) return '';
  400. const obj = _.find(arr, { [key]: col });
  401. return obj ? obj[showKey] : '';
  402. }
  403. });