index.html 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>form</title>
  6. <script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js"></script>
  7. <link href="https://cdn.jsdelivr.net/npm/iview@2.14.3/dist/styles/iview.css" rel="stylesheet">
  8. <script src="https://cdn.jsdelivr.net/npm/iview@2.14.3/dist/iview.js"></script>
  9. <script src="./form-create.min.js"></script>
  10. <script src="http://www.jq22.com/jquery/jquery-1.10.2.js"></script>
  11. <script src="../../../assets/libs/layui/layui.all.js"></script>
  12. </head>
  13. <body>
  14. <div id="page_app">
  15. <div id="app3">
  16. </div>
  17. </div>
  18. <script>
  19. var urlId = getQueryVariable("id");
  20. var urls = getQueryVariable("url");
  21. var aId = getQueryVariable("aId");
  22. var cId = getQueryVariable("cId");
  23. var _m2 = false;
  24. var App = new Vue({
  25. el: '#page_app',
  26. data() {
  27. return {
  28. approverSelectOption: { // 自定义选项 => 审批人人员选择
  29. type: 'select',
  30. name: '审批人',
  31. },
  32. wenbenArr: [], // 文本数据
  33. submitDataArr: [], // 提交数据
  34. approverIndex: null, // 审批人下标
  35. isAddWenbenData: false,
  36. }
  37. },
  38. mounted() {
  39. var _rule = this.getFormRuleData()
  40. var $f_3 = formCreate.create(_rule, {
  41. //表单插入的父级元素
  42. el: '#app3',
  43. //显示表单重置按钮
  44. resetBtn: true,
  45. //表单提交事件
  46. onSubmit: function (formData) {
  47. App.submitData(formData);
  48. //按钮进入提交状态
  49. $f_3.btn.loading();
  50. // 重置按钮禁用
  51. $f_3.resetBtn.disabled();
  52. //按钮进入可点击状态
  53. $f_3.btn.finish();
  54. },
  55. mounted: function () {
  56. _m2 = false;
  57. }
  58. });
  59. },
  60. methods: {
  61. /**
  62. * @Author: NanKeYang
  63. * @Description: 提交数据
  64. * @Data: 2020/1/8 16:43
  65. */
  66. submitData(data) {
  67. var submitDataArr = this.submitDataArr, wenbenArr = this.wenbenArr;
  68. var approverVal = data[this.approverIndex];
  69. console.log(submitDataArr)
  70. if (approverVal <= 0) {
  71. layer.msg('请选择审批人');
  72. return false;
  73. }
  74. for (var key in submitDataArr) {
  75. submitDataArr[key].userVal = data[key]
  76. submitDataArr[key].value = data[key]
  77. if (submitDataArr[key].tipFlagtext) {
  78. delete submitDataArr[key].tipFlagtext
  79. }
  80. }
  81. /**
  82. * @Author: NanKeYang
  83. * @Description: 处理提交失败,重复添加问题
  84. * @Data: 2020/1/8 18:08
  85. */
  86. if (wenbenArr.length > 0 && !this.isAddWenbenData) {
  87. let num = 1
  88. for (let i = 0; i < wenbenArr.length; i++) {
  89. //向数组中添加纯文本对象
  90. submitDataArr.splice(wenbenArr[i].idx + num, 0, {
  91. "type": "label",
  92. "title": wenbenArr[i].tips.title,
  93. "value": wenbenArr[i].tips.value,
  94. "userVal": wenbenArr[i].tips.value
  95. })
  96. //每添加一次数组长度增加1
  97. num++;
  98. }
  99. this.isAddWenbenData = true;
  100. }
  101. $.ajax({
  102. type: "post",
  103. url: urls + "/3rd/flow/add",
  104. data: {
  105. formId: urlId,
  106. formJson: JSON.stringify(submitDataArr),
  107. aId: aId,
  108. cId: cId,
  109. deptLeader: approverVal
  110. },
  111. error: function (request) {
  112. },
  113. success: function (resp) {
  114. if (resp.code == 1) {
  115. $.ajax({
  116. type: "post",
  117. url: urls + "/3rd/flow/holiday",
  118. data: {
  119. aId: aId,
  120. cId: cId,
  121. userFormId: resp.data.userFormId
  122. },
  123. success: function (resp) {
  124. if (resp.code == 1) {
  125. layer.msg('操作成功', {offset: ['50%'], time: 2000}, function () {
  126. parent.layer.closeAll();
  127. });
  128. } else {
  129. layer.msg('操作失败');
  130. }
  131. }
  132. });
  133. } else {
  134. layer.msg('操作失败');
  135. }
  136. }
  137. });
  138. },
  139. /**
  140. * @Author: NanKeYang
  141. * @Description: 获取表单规则
  142. * @Data: 2020/1/8 16:36
  143. */
  144. getFormRuleData() {
  145. var submitDataArr = [], wenbenArr = [];
  146. $.ajax({
  147. type: "get",
  148. url: urls + "/3rd/flow/getById",
  149. data: {
  150. id: urlId,
  151. aId: aId,
  152. cId: cId
  153. },
  154. async: false,
  155. contentType: false,
  156. processData: true,
  157. error: function (request) {
  158. layer.alert('操作失败', {
  159. icon: 2,
  160. title: "提示"
  161. });
  162. },
  163. success: function (resp) {
  164. if (resp.code == 1) {
  165. jsonData = JSON.parse(resp.data.formJson);
  166. } else {
  167. layer.msg(resp.msg);
  168. }
  169. }
  170. });
  171. // 去掉type=lebel的文本数据,并在该数据之前的元素添加文本说明
  172. for (let i = jsonData.length - 1; i >= 0; i--) {
  173. if (jsonData[i].type == 'label') {
  174. // debugger
  175. if (i != 0) {
  176. jsonData[i - 1].tipFlagtext = {title: jsonData[i].title, value: jsonData[i].value}
  177. }
  178. jsonData.splice(i, 1)
  179. }
  180. }
  181. submitDataArr = submitDataArr.concat(jsonData)
  182. for (var key in jsonData) {
  183. if (jsonData[key].tipFlagtext) {
  184. wenbenArr.push({idx: parseInt(key), tips: jsonData[key].tipFlagtext})
  185. }
  186. if (jsonData[key].type == 'text' || jsonData[key].type == 'textarea' || jsonData[key].type == 'password' || jsonData[key].type == 'date') {
  187. jsonData[key] = {
  188. type: "input",
  189. title: jsonData[key].title,
  190. field: key,
  191. value: jsonData[key].value,
  192. props: {
  193. "type": jsonData[key].type,
  194. "placeholder": "请输入内容"
  195. }
  196. }
  197. } else if (jsonData[key].type == 'select-search' || jsonData[key].type == 'checkbox' || jsonData[key].type == 'radio') {
  198. let myOption = [], formType = jsonData[key].type;
  199. let item = jsonData[key].label.split(',');
  200. for (let i = 0; i < item.length; i++) {
  201. myOption.push({"value": item[i], "label": item[i]})
  202. }
  203. if (jsonData[key].type == 'select-search') {
  204. formType = 'select'
  205. }
  206. let typeValue = jsonData[key].value.split(',')
  207. if (jsonData[key].type == 'radio') {
  208. typeValue = typeValue[0]
  209. }
  210. jsonData[key] = {
  211. type: formType,
  212. field: key,
  213. title: jsonData[key].title,
  214. value: typeValue,
  215. options: myOption
  216. }
  217. }
  218. }
  219. this.submitDataArr = submitDataArr;
  220. this.wenbenArr = wenbenArr;
  221. $.ajax({
  222. type: "get",
  223. url: urls + "/3rd/flow/getUsers",
  224. data: {
  225. aId: aId,
  226. cId: cId
  227. },
  228. async: false,
  229. contentType: false,
  230. processData: true,
  231. error: function (request) {
  232. layer.alert('操作失败', {
  233. icon: 2,
  234. title: "提示"
  235. });
  236. },
  237. success: function (resp) {
  238. const {code, data, msg} = resp;
  239. if (code == 1) {
  240. approverList = [];
  241. // 提交要格式 => ID#名称
  242. data.forEach(function (item, index) {
  243. approverList.push({
  244. value: item.aId + '#' + item.accountRealName,
  245. label: item.accountRealName
  246. })
  247. })
  248. } else {
  249. layer.msg(msg);
  250. }
  251. }
  252. });
  253. /**
  254. * @Author: NanKeYang
  255. * @Description: 添加审批人数据
  256. * @Data: 2020/1/8 17:48
  257. */
  258. this.approverIndex = jsonData.length;
  259. jsonData.push(
  260. {
  261. type: this.approverSelectOption.type,
  262. field: jsonData.length + '',
  263. title: this.approverSelectOption.name,
  264. value: '',
  265. options: approverList
  266. }
  267. )
  268. return jsonData;
  269. }
  270. }
  271. })
  272. // //获取url参数
  273. function getQueryVariable(variable) {
  274. var query = window.location.search.substring(1);
  275. var vars = query.split("&");
  276. for (var i = 0; i < vars.length; i++) {
  277. var pair = vars[i].split("=");
  278. if (pair[0] == variable) {
  279. return pair[1];
  280. }
  281. }
  282. return (false);
  283. }
  284. //将纯文本数据隐藏
  285. /*$('.ivu-col').each(function (i, v) {
  286. if($(v).find('.ivu-form-item >label').text() == '纯文本'){
  287. $(v).css('display','none')
  288. }
  289. })*/
  290. </script>
  291. </body>
  292. </html>