index.js 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. const verify = require('../../utils/Check');
  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. },
  22. options: {
  23. multipleSlots: true //允许使用多个slot
  24. },
  25. lifetimes: {
  26. attached: function () {
  27. getApp().globalData.Language.getLanguagePackage(this)
  28. }
  29. },
  30. methods: {
  31. route(e) {
  32. const {
  33. item
  34. } = e.currentTarget.dataset;
  35. if (item.disabled) return;
  36. getApp().globalData.handleSelect = this.handleRoute.bind(this);
  37. wx.navigateTo({
  38. url: item.url + '?params=' + JSON.stringify(item.params) + item.query
  39. })
  40. this.setData({
  41. temporary: {
  42. item: item,
  43. index: this.data.form.findIndex(v => v.valueName == item.valueName)
  44. }
  45. })
  46. },
  47. /* 处理路由返回结果 */
  48. handleRoute(data) {
  49. let temporary = this.data.temporary;
  50. if (temporary.item.interrupt) {
  51. this.triggerEvent("interrupt", {
  52. data,
  53. form: this.data.form,
  54. temporary
  55. });
  56. } else {
  57. wx.navigateBack();
  58. this.setData({
  59. [`form[${temporary.index}].value`]: data.value
  60. });
  61. this.confirm()
  62. }
  63. },
  64. /* 改变值 */
  65. inputChange(e) {
  66. let item = e.target.dataset.item,
  67. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  68. value = e.detail;
  69. //开始校验 //校验规则 不填:不校验 "base":默认校验 "phone":手机号 "mail":邮箱 "正则表达式":以自定义内容为校验标准
  70. if (item.checking) {
  71. let reg = item.checking;
  72. switch (item.checking) {
  73. case 'base':
  74. value = verify.queryStr(value);
  75. break;
  76. case 'phone':
  77. 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}$/;
  78. this.setData({
  79. [`form[${index}].errMsg`]: !reg.test(value) ? getApp().globalData.Language.getMapText('号码格式错误') : ''
  80. });
  81. break;
  82. case 'mail':
  83. reg = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/;
  84. this.setData({
  85. [`form[${index}].errMsg`]: !reg.test(value) ? getApp().globalData.Language.getMapText('请输入正确的邮箱格式') : ''
  86. });
  87. break;
  88. default:
  89. reg = new RegExp(reg);
  90. this.setData({
  91. [`form[${index}].errMsg`]: !reg.test(value) ? item.hint || getApp().globalData.Language.getMapText('输入文本不符合条件!') : ''
  92. });
  93. break;
  94. };
  95. };
  96. this.setData({
  97. [`form[${index}].value`]: value,
  98. [`form[${index}].error`]: false,
  99. });
  100. if (!item.required && value == '') this.setData({
  101. [`form[${index}].errMsg`]: "",
  102. });
  103. this.confirm();
  104. },
  105. /* 日期,时间 选择器 */
  106. bindDateChange(e) {
  107. let item = e.target.dataset.item,
  108. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  109. value = e.detail.value;
  110. this.setData({
  111. [`form[${index}].value`]: value,
  112. [`form[${index}].error`]: false,
  113. });
  114. if (item.interrupt) this.triggerEvent("interrupt", {
  115. data: this.data.form[index],
  116. form: this.data.form
  117. });
  118. this.confirm();
  119. },
  120. /* 时间范围选择器 */
  121. rangeDateChange(e) {
  122. let item = e.target.dataset.item,
  123. i = e.target.dataset.index,
  124. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  125. value = e.detail.value;
  126. this.setData({
  127. [`form[${index}].value[${i}]`]: value,
  128. [`form[${index}].error`]: false,
  129. });
  130. this.confirm();
  131. },
  132. /* 省市县 */
  133. bindRegionChange(e) {
  134. let item = e.currentTarget.dataset.item,
  135. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  136. value = e.detail.value;
  137. this.setData({
  138. [`form[${index}].value`]: value,
  139. [`form[${index}].error`]: false,
  140. });
  141. this.confirm();
  142. },
  143. toOptions(e) {
  144. const {
  145. item
  146. } = e.currentTarget.dataset;
  147. wx.navigateTo({
  148. url: '/packageA/options/index?data=' + JSON.stringify(item),
  149. })
  150. },
  151. /* 自定义选项 */
  152. setOption(item) {
  153. let i = this.data.form.findIndex(v => v.valueName == item.valueName);
  154. this.setData({
  155. [`form[${i}].value`]: item.value
  156. });
  157. this.confirm();
  158. },
  159. /* 是否完成必填项 */
  160. confirm() {
  161. this.triggerEvent("onConfirm", this.data.form.some(v => {
  162. if (v.type == "dateRange" && v.required) {
  163. return v.value[0] == "" || v.value[1] == "";
  164. } else {
  165. return v.required && v.value === '';
  166. }
  167. }));
  168. this.setData({
  169. temporary: null
  170. })
  171. },
  172. /* 性别 */
  173. sexChange(e) {
  174. let item = e.currentTarget.dataset.item,
  175. index = this.data.form.findIndex(v => v.valueName === item.valueName);
  176. this.setData({
  177. [`form[${index}].value`]: e.detail,
  178. [`form[${index}].error`]: false,
  179. });
  180. this.confirm();
  181. },
  182. /* 单选 选择器改变 */
  183. radioChange(e) {
  184. let item = e.currentTarget.dataset.item,
  185. index = this.data.form.findIndex(v => v.valueName == item.valueName);
  186. this.setData({
  187. [`form[${index}].value`]: e.detail,
  188. [`form[${index}].error`]: false,
  189. });
  190. if (item.interrupt) this.triggerEvent("interrupt", {
  191. data: this.data.form[index],
  192. form: this.data.form
  193. });
  194. this.confirm();
  195. },
  196. /* 提交 */
  197. submit() {
  198. let obj = {},
  199. isPass = false;
  200. this.data.form.forEach((v, i) => {
  201. obj[v.valueName] = v.value;
  202. if (v.errMsg != '') {
  203. this.setData({
  204. [`form[${i}].error`]: true
  205. });
  206. isPass = true;
  207. }
  208. });
  209. if (isPass) {
  210. getApp().globalData.Language.showToast('请检查表单内容')
  211. } else {
  212. return obj;
  213. }
  214. },
  215. /* 查询结果 不验证是否必填 */
  216. query() {
  217. let obj = {};
  218. this.data.form.forEach(v => {
  219. obj[v.valueName] = v.value;
  220. });
  221. return obj;
  222. }
  223. }
  224. })