index.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. const verify = require('../../utils/deleteMark');
  2. Component({
  3. externalClasses: [],
  4. properties: {
  5. form: {
  6. type: Array
  7. },
  8. showAll: {
  9. type: Boolean,
  10. value: true
  11. }, //不显示必填项
  12. onConfirm: {
  13. type: Function
  14. },
  15. interrupt: {
  16. type: Function
  17. }, //打断处理,用于条件判断 把form返回到上个页面处理重新传入
  18. },
  19. data: {
  20. temporary: null, //route选择暂存选中项
  21. voiceIndex: null,
  22. seconds: 60,
  23. },
  24. options: {
  25. multipleSlots: true //允许使用多个slot
  26. },
  27. methods: {
  28. onVoiceInput(e) {
  29. this.setData({
  30. [`form[${e.currentTarget.dataset.index}].value`]: e.detail
  31. });
  32. this.confirm();
  33. },
  34. toOptions(e) {
  35. const {
  36. item
  37. } = e.currentTarget.dataset;
  38. wx.navigateTo({
  39. url: '/packageA/options/index?data=' + JSON.stringify(item),
  40. })
  41. },
  42. route(e) {
  43. const {
  44. item
  45. } = e.currentTarget.dataset;
  46. if (item.disabled) return;
  47. getApp().globalData.handleSelect = this.handleRoute.bind(this);
  48. let result = (item.query && !item.query.indexOf("radio=true") && item.value[1]) ? `` : `&result=${JSON.stringify(item.value[1])}`
  49. wx.navigateTo({
  50. url: item.url + '?params=' + JSON.stringify(item.params) + (item.query || '') + result,
  51. fail(err) {
  52. console.log(err)
  53. }
  54. });
  55. this.setData({
  56. temporary: {
  57. item: item,
  58. index: this.data.form.findIndex(v => v.valueName == item.valueName)
  59. }
  60. })
  61. },
  62. /* 处理路由返回结果 */
  63. handleRoute(data) {
  64. let temporary = this.data.temporary;
  65. if (temporary.item.interrupt) {
  66. this.triggerEvent("interrupt", {
  67. data,
  68. form: this.data.form,
  69. temporary
  70. });
  71. } else {
  72. wx.navigateBack();
  73. this.setData({
  74. [`form[${temporary.index}].value`]: data.value
  75. });
  76. this.confirm()
  77. };
  78. this.data.temporary = null;
  79. },
  80. onBlur(e) {
  81. let item = e.target.dataset.item,
  82. index = this.data.form.findIndex(v => v.valueName === item.valueName);
  83. if (item.interrupt) this.triggerEvent("interrupt", {
  84. data: this.data.form[index],
  85. form: this.data.form,
  86. temporary: {
  87. item,
  88. index
  89. }
  90. });
  91. },
  92. /* 改变值 */
  93. inputChange(e) {
  94. let item = e.target.dataset.item,
  95. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  96. value = e.detail;
  97. //校验规则 不填:不校验 "base":默认校验 "phone":手机号 "mail":邮箱 "telephone":固定电话 "正则表达式":以自定义内容为校验标准
  98. if (item.checking) {
  99. let reg = item.checking;
  100. switch (item.checking) {
  101. case 'base':
  102. value = verify.queryStr(value);
  103. break;
  104. case 'phone':
  105. reg = /^1(3[0-9]|4[01456879]|5[0-35-9]|6[2567]|7[0-8]|8[0-9]|9[0-35-9])\d{8}$/;
  106. this.setData({
  107. [`form[${index}].errMsg`]: !reg.test(value) ? '请输入正确11位手机号码' : ''
  108. });
  109. break;
  110. case "telephone":
  111. let i = e.target.dataset.i;
  112. value = item.value;
  113. value[i] = e.detail.value;
  114. let result = value[0] + "-" + value[1];
  115. reg = /^0\d{2,3}-[1-9]\d{6,7}$/
  116. this.setData({
  117. [`form[${index}].errMsg`]: !reg.test(result) ? '请填写正确的座机电话' : '',
  118. [`form[${index}].result`]: result,
  119. });
  120. break;
  121. case 'mail':
  122. reg = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/;
  123. this.setData({
  124. [`form[${index}].errMsg`]: !reg.test(value) ? '请输入正确的邮箱格式' : ''
  125. });
  126. break;
  127. case 'twoDecimalPlaces':
  128. reg = /^(\d+(?:\.\d{0,2})?)?$/;
  129. this.setData({
  130. [`form[${index}].errMsg`]: !reg.test(value) ? '仅允许保留2位小数' : ''
  131. });
  132. break;
  133. default:
  134. reg = new RegExp(reg);
  135. this.setData({
  136. [`form[${index}].errMsg`]: !reg.test(value) ? (item.hint || '输入文本不符合条件!') : ''
  137. });
  138. break;
  139. };
  140. };
  141. this.setData({
  142. [`form[${index}].value`]: value,
  143. [`form[${index}].error`]: false,
  144. });
  145. if (!item.required && value == '') this.setData({
  146. [`form[${index}].errMsg`]: "",
  147. });
  148. this.confirm();
  149. },
  150. /* 单列选择器 */
  151. bindSelectorChange(e) {
  152. let {
  153. item,
  154. index
  155. } = e.target.dataset,
  156. value = e.detail.value;
  157. this.setData({
  158. [`form[${index}].value`]: item.range[value][item.rangeKey],
  159. [`form[${index}].rangeIndex`]: value,
  160. [`form[${index}].error`]: false,
  161. });
  162. if (item.interrupt) this.triggerEvent("interrupt", {
  163. data: this.data.form[index],
  164. form: this.data.form,
  165. temporary: {
  166. item,
  167. index
  168. }
  169. });
  170. this.confirm();
  171. },
  172. /* 日期,时间 选择器 */
  173. bindDateChange(e) {
  174. let item = e.target.dataset.item,
  175. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  176. value = e.detail.value;
  177. this.setData({
  178. [`form[${index}].value`]: value,
  179. [`form[${index}].error`]: false,
  180. });
  181. if (item.interrupt) this.triggerEvent("interrupt", {
  182. data: this.data.form[index],
  183. form: this.data.form,
  184. temporary: {
  185. item,
  186. index
  187. }
  188. });
  189. this.confirm();
  190. },
  191. /* 时间范围选择器 */
  192. rangeDateChange(e) {
  193. let item = e.target.dataset.item,
  194. i = e.target.dataset.index,
  195. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  196. value = e.detail.value;
  197. this.setData({
  198. [`form[${index}].value[${i}]`]: value,
  199. [`form[${index}].error`]: false,
  200. });
  201. this.confirm();
  202. },
  203. /* 省市县 */
  204. bindRegionChange(e) {
  205. let item = e.currentTarget.dataset.item,
  206. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  207. value = e.detail.value;
  208. this.setData({
  209. [`form[${index}].value`]: value,
  210. [`form[${index}].error`]: false,
  211. });
  212. this.confirm();
  213. },
  214. /* 自定义选项 */
  215. setOption(item) {
  216. let i = this.data.form.findIndex(v => v.valueName == item.valueName);
  217. this.setData({
  218. [`form[${i}].value`]: item.value
  219. });
  220. this.confirm();
  221. },
  222. /* 是否完成必填项 */
  223. confirm() {
  224. this.triggerEvent("onConfirm", this.data.form.some(v => {
  225. if (v.type == "dateRange" && v.required) {
  226. return v.value[0] == "" || v.value[1] == "";
  227. } else {
  228. return v.required && v.value == '';
  229. }
  230. }))
  231. },
  232. /* 性别 */
  233. sexChange(e) {
  234. let item = e.currentTarget.dataset.item,
  235. index = this.data.form.findIndex(v => v.valueName === item.valueName);
  236. this.setData({
  237. [`form[${index}].value`]: e.detail,
  238. [`form[${index}].error`]: false,
  239. });
  240. this.confirm();
  241. },
  242. /* 单选 选择器改变 */
  243. radioChange(e) {
  244. let item = e.currentTarget.dataset.item,
  245. index = this.data.form.findIndex(v => v.valueName == item.valueName);
  246. if (this.data.form[index].value == e.detail) return;
  247. this.setData({
  248. [`form[${index}].value`]: e.detail,
  249. [`form[${index}].error`]: false,
  250. });
  251. if (item.interrupt) this.triggerEvent("interrupt", {
  252. data: this.data.form[index],
  253. form: this.data.form,
  254. temporary: {
  255. item,
  256. index
  257. }
  258. });
  259. this.confirm();
  260. },
  261. /* 提交 */
  262. submit() {
  263. let obj = {},
  264. isPass = false;
  265. this.data.form.forEach((v, i) => {
  266. obj[v.valueName] = v.value;
  267. // permit 无视errMsg 允许通过
  268. if (!v.permit && v.errMsg != '') {
  269. this.setData({
  270. [`form[${i}].error`]: true
  271. });
  272. isPass = true;
  273. }
  274. });
  275. if (isPass) {
  276. wx.showToast({
  277. title: '请检查表单内容',
  278. icon: "none"
  279. })
  280. } else {
  281. return obj;
  282. }
  283. },
  284. /* 查询结果 不验证是否必填 */
  285. query() {
  286. let obj = {};
  287. this.data.form.forEach(v => obj[v.valueName] = v.value);
  288. return obj;
  289. }
  290. }
  291. })