login-dialog.js 35 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087
  1. exports.ids = [16,20];
  2. exports.modules = {
  3. /***/ 221:
  4. /***/ (function(module, exports) {
  5. // Exports
  6. module.exports = {
  7. };
  8. /***/ }),
  9. /***/ 244:
  10. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  11. "use strict";
  12. __webpack_require__.r(__webpack_exports__);
  13. /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcGlobalForm_vue_vue_type_style_index_0_id_4b4d0fec_prod_lang_scss_scope_true__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(221);
  14. /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcGlobalForm_vue_vue_type_style_index_0_id_4b4d0fec_prod_lang_scss_scope_true__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcGlobalForm_vue_vue_type_style_index_0_id_4b4d0fec_prod_lang_scss_scope_true__WEBPACK_IMPORTED_MODULE_0__);
  15. /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcGlobalForm_vue_vue_type_style_index_0_id_4b4d0fec_prod_lang_scss_scope_true__WEBPACK_IMPORTED_MODULE_0__) if(["default"].indexOf(__WEBPACK_IMPORT_KEY__) < 0) (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcGlobalForm_vue_vue_type_style_index_0_id_4b4d0fec_prod_lang_scss_scope_true__WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__));
  16. /***/ }),
  17. /***/ 282:
  18. /***/ (function(module, exports) {
  19. // Exports
  20. module.exports = {
  21. };
  22. /***/ }),
  23. /***/ 294:
  24. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  25. "use strict";
  26. // ESM COMPAT FLAG
  27. __webpack_require__.r(__webpack_exports__);
  28. // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/PcGlobalForm.vue?vue&type=template&id=4b4d0fec
  29. var render = function render() {
  30. var _vm = this,
  31. _c = _vm._self._c;
  32. return _c('div', {
  33. staticClass: "form global-form"
  34. }, [_c('el-form', {
  35. ref: "ruleForm",
  36. staticClass: "form-list",
  37. attrs: {
  38. "model": _vm.formData,
  39. "rules": _vm.rules
  40. }
  41. }, _vm._l(_vm.formConfig, function (item) {
  42. return _c('el-form-item', {
  43. key: item.label,
  44. attrs: {
  45. "prop": item.prop
  46. }
  47. }, [item.type === 'input' ? _c('el-input', {
  48. style: {
  49. width: item.width
  50. },
  51. attrs: {
  52. "disabled": item.disabled,
  53. "placeholder": item.placeholder,
  54. "clearable": ""
  55. },
  56. on: {
  57. "change": function ($event) {
  58. item.change && item.change(_vm.formData[item.prop]);
  59. }
  60. },
  61. model: {
  62. value: _vm.formData[item.prop],
  63. callback: function ($$v) {
  64. _vm.$set(_vm.formData, item.prop, $$v);
  65. },
  66. expression: "formData[item.prop]"
  67. }
  68. }) : _vm._e(), _vm._v(" "), item.type === 'password' ? _c('el-input', {
  69. style: {
  70. width: item.width
  71. },
  72. attrs: {
  73. "type": _vm.flag ? 'text' : 'password',
  74. "autocomplete": "off",
  75. "placeholder": item.placeholder,
  76. "clearable": ""
  77. },
  78. on: {
  79. "change": function ($event) {
  80. item.change && item.change(_vm.formData[item.prop]);
  81. }
  82. },
  83. model: {
  84. value: _vm.formData[item.prop],
  85. callback: function ($$v) {
  86. _vm.$set(_vm.formData, item.prop, $$v);
  87. },
  88. expression: "formData[item.prop]"
  89. }
  90. }, [!_vm.flag ? _c('i', {
  91. staticClass: "el-input__icon iconfont",
  92. staticStyle: {
  93. "font-size": "22px"
  94. },
  95. attrs: {
  96. "slot": "suffix"
  97. },
  98. on: {
  99. "click": _vm.showPassword
  100. },
  101. slot: "suffix"
  102. }, [_vm._v("")]) : _c('i', {
  103. staticClass: "el-input__icon iconfont",
  104. staticStyle: {
  105. "font-size": "22px"
  106. },
  107. attrs: {
  108. "slot": "suffix"
  109. },
  110. on: {
  111. "click": _vm.showPassword
  112. },
  113. slot: "suffix"
  114. }, [_vm._v("")])]) : _vm._e(), _vm._v(" "), item.type === 'textarea' ? _c('el-input', {
  115. style: {
  116. width: item.width
  117. },
  118. attrs: {
  119. "type": "textarea",
  120. "disabled": item.disabled,
  121. "maxlength": item.maxlength,
  122. "rows": item.rows,
  123. "show-word-limit": item.showWordLimit
  124. },
  125. on: {
  126. "change": function ($event) {
  127. item.change && item.change(_vm.formData[item.prop]);
  128. }
  129. },
  130. model: {
  131. value: _vm.formData[item.prop],
  132. callback: function ($$v) {
  133. _vm.$set(_vm.formData, item.prop, $$v);
  134. },
  135. expression: "formData[item.prop]"
  136. }
  137. }) : _vm._e(), _vm._v(" "), item.type === 'select' ? _c('el-select', {
  138. style: {
  139. width: item.width
  140. },
  141. attrs: {
  142. "disabled": item.disabled,
  143. "clearable": "",
  144. "multiple": _vm.multiple,
  145. "placeholder": item.placeholder
  146. },
  147. on: {
  148. "change": function ($event) {
  149. item.change && item.change(_vm.formData[item.prop]);
  150. }
  151. },
  152. model: {
  153. value: _vm.formData[item.prop],
  154. callback: function ($$v) {
  155. _vm.$set(_vm.formData, item.prop, $$v);
  156. },
  157. expression: "formData[item.prop]"
  158. }
  159. }, _vm._l(item.selectList, function (option) {
  160. return _c('el-option', {
  161. key: option.id,
  162. attrs: {
  163. "label": option.name,
  164. "value": option.id
  165. }
  166. });
  167. }), 1) : _vm._e(), _vm._v(" "), item.type === 'selectObj' ? _c('el-select', {
  168. style: {
  169. width: item.width
  170. },
  171. attrs: {
  172. "disabled": item.disabled,
  173. "filterable": "",
  174. "clearable": "",
  175. "placeholder": item.placeholder
  176. },
  177. on: {
  178. "change": function ($event) {
  179. item.change && item.change(_vm.formData[item.prop]);
  180. }
  181. },
  182. model: {
  183. value: _vm.formData[item.prop],
  184. callback: function ($$v) {
  185. _vm.$set(_vm.formData, item.prop, $$v);
  186. },
  187. expression: "formData[item.prop]"
  188. }
  189. }, _vm._l(item.selectList, function (item, key) {
  190. return _c('el-option', {
  191. key: parseInt(key),
  192. attrs: {
  193. "label": item,
  194. "value": parseInt(key)
  195. }
  196. });
  197. }), 1) : _vm._e(), _vm._v(" "), item.type === 'radio' ? _c('el-radio-group', {
  198. attrs: {
  199. "disabled": item.disabled
  200. },
  201. on: {
  202. "change": function ($event) {
  203. item.change && item.change(_vm.formData[item.prop]);
  204. }
  205. },
  206. model: {
  207. value: _vm.formData[item.prop],
  208. callback: function ($$v) {
  209. _vm.$set(_vm.formData, item.prop, $$v);
  210. },
  211. expression: "formData[item.prop]"
  212. }
  213. }, _vm._l(item.radios, function (radio) {
  214. return _c('el-radio', {
  215. key: radio.label,
  216. attrs: {
  217. "label": radio.label
  218. }
  219. });
  220. }), 1) : _vm._e(), _vm._v(" "), item.type === 'checkbox' ? _c('el-checkbox-group', {
  221. attrs: {
  222. "disabled": item.disabled
  223. },
  224. on: {
  225. "change": function ($event) {
  226. item.change && item.change(_vm.formData[item.prop]);
  227. }
  228. },
  229. model: {
  230. value: _vm.formData[item.prop],
  231. callback: function ($$v) {
  232. _vm.$set(_vm.formData, item.prop, $$v);
  233. },
  234. expression: "formData[item.prop]"
  235. }
  236. }, _vm._l(item.checkboxs, function (item) {
  237. return _c('el-checkbox', {
  238. key: item.label,
  239. attrs: {
  240. "label": item.label
  241. }
  242. }, [_vm._v(_vm._s(item.label))]);
  243. }), 1) : _vm._e(), _vm._v(" "), item.type === 'switch' ? _c('el-switch', {
  244. attrs: {
  245. "disabled": item.disabled
  246. },
  247. on: {
  248. "change": function ($event) {
  249. item.change && item.change(_vm.formData[item.prop]);
  250. }
  251. },
  252. model: {
  253. value: _vm.formData[item.prop],
  254. callback: function ($$v) {
  255. _vm.$set(_vm.formData, item.prop, $$v);
  256. },
  257. expression: "formData[item.prop]"
  258. }
  259. }) : _vm._e(), _vm._v(" "), item.type === 'slot' ? [_vm._t(item.slotName)] : _vm._e()], 2);
  260. }), 1), _vm._ssrNode(" "), _vm._ssrNode("<div class=\"submit-btn\">", "</div>", [_vm.showLoginBtn ? _c('el-button', {
  261. attrs: {
  262. "loading": _vm.submitLoading
  263. },
  264. nativeOn: {
  265. "click": function ($event) {
  266. return _vm.submit.apply(null, arguments);
  267. }
  268. }
  269. }, [_vm._v("\n LOGIN\n ")]) : _vm._e(), _vm._ssrNode(" "), _vm.showRegisterBtn ? _c('el-button', {
  270. attrs: {
  271. "loading": _vm.submitLoading
  272. },
  273. nativeOn: {
  274. "click": function ($event) {
  275. return _vm.submit.apply(null, arguments);
  276. }
  277. }
  278. }, [_vm._v("\n REGISTER\n ")]) : _vm._e(), _vm._ssrNode(" "), _vm.showDeleteBtn ? _c('el-button', {
  279. nativeOn: {
  280. "click": function ($event) {
  281. return _vm.close.apply(null, arguments);
  282. }
  283. }
  284. }, [_vm._v("取 消")]) : _vm._e()], 2)], 2);
  285. };
  286. var staticRenderFns = [];
  287. // CONCATENATED MODULE: ./components/PcGlobalForm.vue?vue&type=template&id=4b4d0fec
  288. // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/PcGlobalForm.vue?vue&type=script&lang=js
  289. /* harmony default export */ var PcGlobalFormvue_type_script_lang_js = ({
  290. name: "GlobalForm",
  291. props: {
  292. showDeleteBtn: {
  293. type: Boolean,
  294. default: true
  295. },
  296. showLoginBtn: {
  297. type: Boolean,
  298. default: true
  299. },
  300. showRegisterBtn: {
  301. type: Boolean,
  302. default: true
  303. },
  304. // 表单配置
  305. formConfig: {
  306. type: Array,
  307. required: true
  308. },
  309. // 表单数据
  310. formData: {
  311. type: Object,
  312. required: true
  313. },
  314. // 表单规则
  315. rules: {
  316. type: Object
  317. },
  318. submitLoading: {
  319. type: Boolean
  320. }
  321. },
  322. data() {
  323. return {
  324. flag: false
  325. };
  326. },
  327. methods: {
  328. submit() {
  329. this.$refs.ruleForm.validate(valid => {
  330. if (valid) {
  331. this.$emit("handleSubmit");
  332. } else {
  333. console.log("error submit!!");
  334. return false;
  335. }
  336. });
  337. },
  338. close() {
  339. this.$emit("handleClose");
  340. },
  341. showPassword() {
  342. this.flag = !this.flag;
  343. }
  344. }
  345. });
  346. // CONCATENATED MODULE: ./components/PcGlobalForm.vue?vue&type=script&lang=js
  347. /* harmony default export */ var components_PcGlobalFormvue_type_script_lang_js = (PcGlobalFormvue_type_script_lang_js);
  348. // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
  349. var componentNormalizer = __webpack_require__(2);
  350. // CONCATENATED MODULE: ./components/PcGlobalForm.vue
  351. function injectStyles (context) {
  352. var style0 = __webpack_require__(244)
  353. if (style0.__inject__) style0.__inject__(context)
  354. }
  355. /* normalize component */
  356. var component = Object(componentNormalizer["a" /* default */])(
  357. components_PcGlobalFormvue_type_script_lang_js,
  358. render,
  359. staticRenderFns,
  360. false,
  361. injectStyles,
  362. null,
  363. "905cdef0"
  364. )
  365. /* harmony default export */ var PcGlobalForm = __webpack_exports__["default"] = (component.exports);
  366. /***/ }),
  367. /***/ 338:
  368. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  369. "use strict";
  370. __webpack_require__.r(__webpack_exports__);
  371. /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_loginDialog_vue_vue_type_style_index_0_id_0b8b973d_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(282);
  372. /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_loginDialog_vue_vue_type_style_index_0_id_0b8b973d_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_loginDialog_vue_vue_type_style_index_0_id_0b8b973d_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__);
  373. /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_loginDialog_vue_vue_type_style_index_0_id_0b8b973d_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__) if(["default"].indexOf(__WEBPACK_IMPORT_KEY__) < 0) (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_loginDialog_vue_vue_type_style_index_0_id_0b8b973d_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__));
  374. /***/ }),
  375. /***/ 373:
  376. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  377. "use strict";
  378. // ESM COMPAT FLAG
  379. __webpack_require__.r(__webpack_exports__);
  380. // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/loginDialog.vue?vue&type=template&id=0b8b973d&scoped=true
  381. var render = function render() {
  382. var _vm$config$configInfo, _vm$config$configInfo2;
  383. var _vm = this,
  384. _c = _vm._self._c;
  385. return _c('div', [_c('el-dialog', {
  386. attrs: {
  387. "custom-class": _vm.activeName === 'first' ? 'custom-login-form' : 'custom-register-form',
  388. "lock-scroll": false,
  389. "visible": _vm.dialogVisible,
  390. "width": _vm.dialogWidth,
  391. "before-close": _vm.close
  392. },
  393. on: {
  394. "update:visible": function ($event) {
  395. _vm.dialogVisible = $event;
  396. }
  397. }
  398. }, [_c('el-tabs', {
  399. model: {
  400. value: _vm.activeName,
  401. callback: function ($$v) {
  402. _vm.activeName = $$v;
  403. },
  404. expression: "activeName"
  405. }
  406. }, [_c('el-tab-pane', {
  407. attrs: {
  408. "label": "LOGIN",
  409. "name": "first"
  410. }
  411. }, [_c('GlobalForm', {
  412. ref: "loginForm",
  413. attrs: {
  414. "formData": _vm.loginData,
  415. "formConfig": _vm.loginFormConfig,
  416. "rules": _vm.loginRules,
  417. "submitLoading": _vm.submitLoading,
  418. "showDeleteBtn": _vm.showDeleteBtn,
  419. "showRegisterBtn": false
  420. },
  421. on: {
  422. "handleSubmit": _vm.submit
  423. },
  424. scopedSlots: _vm._u([{
  425. key: "checkbox",
  426. fn: function () {
  427. return [_c('div', {
  428. staticClass: "rememberMe"
  429. }, [_c('el-checkbox', {
  430. model: {
  431. value: _vm.isRemember,
  432. callback: function ($$v) {
  433. _vm.isRemember = $$v;
  434. },
  435. expression: "isRemember"
  436. }
  437. }, [_vm._v("Remember me")]), _vm._v(" "), _c('div', {
  438. staticClass: "btn-forgot-pw",
  439. on: {
  440. "click": _vm.resetPassword
  441. }
  442. }, [_vm._v("\n Forgot Password\n ")])], 1)];
  443. },
  444. proxy: true
  445. }])
  446. }), _vm._v(" "), _c('div', {
  447. staticStyle: {
  448. "font-size": "14px",
  449. "color": "#666",
  450. "margin-top": "18px",
  451. "text-align": "right"
  452. }
  453. }, [_vm._v("\n Strictly distributors only. Proof of status will be required\n ")])], 1), _vm._v(" "), _c('el-tab-pane', {
  454. attrs: {
  455. "label": "REGISTER AS A NEW USER",
  456. "name": "second"
  457. }
  458. }, [_c('div', {
  459. staticClass: "flex start"
  460. }, [_c('div', {
  461. staticStyle: {
  462. "width": "50%",
  463. "min-width": "50%",
  464. "padding-top": "48px"
  465. }
  466. }, [_c('div', {
  467. staticClass: "flex center",
  468. staticStyle: {
  469. "margin-bottom": "55px"
  470. }
  471. }, [_c('img', {
  472. attrs: {
  473. "src": __webpack_require__(33),
  474. "alt": "PromoCollection Logo"
  475. }
  476. })]), _vm._v(" "), _c('div', {
  477. staticClass: "desc-content main-desc"
  478. }, [_vm._v("\n PromoCollection is Australia's fastest growing\n "), _c('br'), _vm._v("\n promotional products supplier, 5 years in a row!\n ")]), _vm._v(" "), _c('p', {
  479. staticClass: "desc-content"
  480. }, [_vm._v("\n We work exclusively with distributors to offer over 2000\n catalogue products, as well as a world of sourcing options, with\n our 60 person offshore sourcing team,to source anything you\n need!\n ")]), _vm._v(" "), _c('div', {
  481. staticClass: "desc-content"
  482. }, [_vm._v("\n To apply for a login, please input the below information\n ")]), _vm._v(" "), (_vm$config$configInfo = _vm.config.configInfo) !== null && _vm$config$configInfo !== void 0 && _vm$config$configInfo.image ? _c('div', {
  483. staticClass: "signature-image flex center"
  484. }, [_c('img', {
  485. class: {
  486. pointer: (_vm$config$configInfo2 = _vm.config.configInfo) === null || _vm$config$configInfo2 === void 0 ? void 0 : _vm$config$configInfo2.link
  487. },
  488. attrs: {
  489. "src": _vm.config.configInfo.image,
  490. "alt": ""
  491. },
  492. on: {
  493. "click": _vm.toSignatureLink
  494. }
  495. })]) : _vm._e()]), _vm._v(" "), _c('div', {
  496. staticClass: "flex-auto register-form"
  497. }, [_c('el-form', {
  498. ref: "registForm",
  499. attrs: {
  500. "inline": true,
  501. "model": _vm.registData,
  502. "rules": _vm.registRules,
  503. "label-position": "top"
  504. }
  505. }, _vm._l(_vm.registFormConfig, function (item) {
  506. return _c('el-form-item', {
  507. key: item.label,
  508. class: {
  509. 'long-form-item': item.long,
  510. 'short-form-item': !item.long
  511. },
  512. attrs: {
  513. "prop": item.prop,
  514. "label": item.placeholder
  515. }
  516. }, [item.type === 'password' ? _c('el-input', {
  517. attrs: {
  518. "type": _vm.showPassword ? 'text' : 'password'
  519. },
  520. model: {
  521. value: _vm.registData[item.prop],
  522. callback: function ($$v) {
  523. _vm.$set(_vm.registData, item.prop, $$v);
  524. },
  525. expression: "registData[item.prop]"
  526. }
  527. }, [!_vm.showPassword ? _c('i', {
  528. staticClass: "el-input__icon iconfont",
  529. staticStyle: {
  530. "font-size": "22px",
  531. "cursor": "pointer",
  532. "color": "#666"
  533. },
  534. attrs: {
  535. "slot": "suffix"
  536. },
  537. on: {
  538. "click": function ($event) {
  539. _vm.showPassword = true;
  540. }
  541. },
  542. slot: "suffix"
  543. }, [_vm._v("")]) : _c('i', {
  544. staticClass: "el-input__icon iconfont",
  545. staticStyle: {
  546. "font-size": "22px",
  547. "cursor": "pointer",
  548. "color": "#666"
  549. },
  550. attrs: {
  551. "slot": "suffix"
  552. },
  553. on: {
  554. "click": function ($event) {
  555. _vm.showPassword = false;
  556. }
  557. },
  558. slot: "suffix"
  559. }, [_vm._v("")])]) : _c('el-input', {
  560. attrs: {
  561. "id": item.prop + '_input'
  562. },
  563. on: {
  564. "change": $e => _vm.onInputChange($e, item.prop)
  565. },
  566. model: {
  567. value: _vm.registData[item.prop],
  568. callback: function ($$v) {
  569. _vm.$set(_vm.registData, item.prop, $$v);
  570. },
  571. expression: "registData[item.prop]"
  572. }
  573. })], 1);
  574. }), 1), _vm._v(" "), _c('div', {
  575. staticClass: "flex center"
  576. }, [_c('el-button', {
  577. attrs: {
  578. "loading": _vm.submitLoading
  579. },
  580. on: {
  581. "click": _vm.checkRegisterForm
  582. }
  583. }, [_vm._v("REGISTER")])], 1), _vm._v(" "), _c('p', {
  584. staticClass: "desc-content"
  585. }, [_vm._v("* required")])], 1)])])], 1)], 1), _vm._ssrNode(" "), _c('resetPasswordDialog', {
  586. ref: "resetPasswordDialog",
  587. on: {
  588. "openLoginDialog": _vm.openLoginDialog
  589. }
  590. }), _vm._ssrNode(" "), _c('dialog-XX-success', {
  591. attrs: {
  592. "visible": _vm.xxContentVisible,
  593. "content": _vm.xxContent
  594. },
  595. on: {
  596. "update:visible": function ($event) {
  597. _vm.xxContentVisible = $event;
  598. }
  599. }
  600. })], 2);
  601. };
  602. var staticRenderFns = [];
  603. // CONCATENATED MODULE: ./components/loginDialog.vue?vue&type=template&id=0b8b973d&scoped=true
  604. // EXTERNAL MODULE: external "vuex"
  605. var external_vuex_ = __webpack_require__(6);
  606. // EXTERNAL MODULE: ./components/PcGlobalForm.vue + 4 modules
  607. var PcGlobalForm = __webpack_require__(294);
  608. // EXTERNAL MODULE: ./components/DIalogXXSuccess.vue + 4 modules
  609. var DIalogXXSuccess = __webpack_require__(30);
  610. // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/loginDialog.vue?vue&type=script&lang=js
  611. const Base64 = __webpack_require__(146).Base64;
  612. /* harmony default export */ var loginDialogvue_type_script_lang_js = ({
  613. name: 'LoginDialog',
  614. components: {
  615. GlobalForm: PcGlobalForm["default"],
  616. 'dialog-XX-success': DIalogXXSuccess["default"]
  617. },
  618. data() {
  619. return {
  620. showPassword: false,
  621. xxContentVisible: false,
  622. xxContent: 'success',
  623. isRemember: false,
  624. showDeleteBtn: false,
  625. activeName: 'first',
  626. submitLoading: false,
  627. loginData: {
  628. email: '',
  629. password: ''
  630. },
  631. registData: {},
  632. // 表单配置
  633. loginFormConfig: [{
  634. autoInput: true,
  635. prop: 'email',
  636. type: 'input',
  637. placeholder: 'User Name'
  638. }, {
  639. prop: 'password',
  640. type: 'password',
  641. placeholder: 'Password'
  642. }, {
  643. type: 'slot',
  644. slotName: 'checkbox'
  645. }],
  646. registFormConfig: [{
  647. long: true,
  648. prop: 'email',
  649. type: 'input',
  650. placeholder: 'Email'
  651. }, {
  652. long: true,
  653. prop: 'password',
  654. type: 'password',
  655. placeholder: 'Password'
  656. }, {
  657. long: true,
  658. prop: 'confirm_password',
  659. type: 'password',
  660. placeholder: 'Comfirm Password'
  661. }, {
  662. prop: 'contacts',
  663. type: 'input',
  664. placeholder: 'First Name'
  665. }, {
  666. prop: 'last_name',
  667. type: 'input',
  668. placeholder: 'Last Name'
  669. }, {
  670. long: true,
  671. prop: 'company',
  672. type: 'input',
  673. placeholder: 'Company Name'
  674. }, {
  675. prop: 'phone',
  676. type: 'input',
  677. placeholder: 'Phone No'
  678. }, {
  679. prop: 'url',
  680. type: 'input',
  681. placeholder: 'Website'
  682. }, {
  683. long: true,
  684. prop: 'address',
  685. type: 'input',
  686. placeholder: 'Address'
  687. }, {
  688. prop: 'state',
  689. type: 'input',
  690. placeholder: 'State'
  691. }, {
  692. prop: 'postcode',
  693. type: 'input',
  694. placeholder: 'Post Code'
  695. }],
  696. // 表单规则
  697. loginRules: {
  698. email: [{
  699. required: true,
  700. message: 'Please enter the correct email',
  701. trigger: 'blur'
  702. }],
  703. password: [{
  704. required: true,
  705. message: 'The password length only allows 6-16 bits',
  706. trigger: 'blur',
  707. min: 6,
  708. max: 16
  709. }]
  710. },
  711. registRules: {
  712. email: [{
  713. required: true,
  714. message: 'Please enter your email address',
  715. trigger: 'blur'
  716. }],
  717. password: [{
  718. required: true,
  719. message: 'The password length only allows 6-16 bits',
  720. trigger: 'blur',
  721. min: 6,
  722. max: 16
  723. }],
  724. confirm_password: [{
  725. required: true,
  726. message: 'The password length only allows 6-16 bits',
  727. trigger: 'blur',
  728. min: 6,
  729. max: 16
  730. }],
  731. company: [{
  732. required: true,
  733. message: 'Please enter your company name',
  734. trigger: 'blur'
  735. }],
  736. contacts: [{
  737. required: true,
  738. message: 'Please enter your contact person',
  739. trigger: 'blur'
  740. }],
  741. last_name: [{
  742. required: true,
  743. message: 'Please enter your contact person',
  744. trigger: 'blur'
  745. }],
  746. phone: [{
  747. required: true,
  748. message: 'Please enter your phone number',
  749. trigger: 'blur'
  750. }]
  751. },
  752. autoComplete: null,
  753. // 记录谷歌地图API选择地点后拿到的地址名. 这个不能直接更新到registeData上, 不然输入框内容会再次变化.
  754. selectAddress: ''
  755. };
  756. },
  757. computed: {
  758. ...Object(external_vuex_["mapState"])(['dialogVisible', 'config']),
  759. dialogWidth() {
  760. return this.activeName === 'first' ? '506px' : '1108px';
  761. }
  762. },
  763. watch: {
  764. dialogVisible(value) {
  765. if (value) {
  766. document.addEventListener('keydown', this.onEnterClick);
  767. } else {
  768. document.removeEventListener('keydown', this.onEnterClick);
  769. }
  770. },
  771. activeName() {
  772. if (this.activeName === 'second' && this.autoComplete === null) {
  773. if (window.google) {
  774. this.initGoogleMapAutoComplete();
  775. this.getAddrByLocation();
  776. } else {
  777. setTimeout(() => {
  778. this.initGoogleMapAutoComplete();
  779. this.getAddrByLocation();
  780. }, 1500);
  781. }
  782. }
  783. }
  784. },
  785. mounted() {
  786. this.getCookie();
  787. },
  788. methods: {
  789. ...Object(external_vuex_["mapMutations"])(['closeDialog', 'openDialog']),
  790. onEnterClick(e) {
  791. if (e.keyCode === 13) {
  792. console.log('enter');
  793. let target = this.$refs.loginForm;
  794. if (this.activeName === 'first') {
  795. // do nothing. login form
  796. }
  797. if (this.activeName === 'second') {
  798. target = this.$refs.registForm;
  799. }
  800. if (typeof target.submit === 'function') {
  801. target.submit();
  802. }
  803. }
  804. },
  805. checkRegisterForm() {
  806. this.$refs.registForm.validate(valid => {
  807. if (valid) {
  808. this.submit();
  809. }
  810. });
  811. },
  812. submit() {
  813. if (this.activeName === 'first') {
  814. if (this.isRemember) {
  815. const password = Base64.encode(this.loginData.password);
  816. this.setCookie(this.loginData.email, password, 7);
  817. } else {
  818. this.setCookie('', '', -1);
  819. }
  820. this.login();
  821. } else if (this.activeName === 'second') {
  822. this.regist();
  823. }
  824. },
  825. login() {
  826. this.$store.dispatch('login', this.loginData).then(res => {
  827. if (res.code == 1) {
  828. setTimeout(() => {
  829. this.closeDialog();
  830. }, 200);
  831. this.xxContentVisible = true;
  832. this.xxContent = 'Login Successful';
  833. this.submitLoading = false;
  834. // this.$confirm("Login Successful", {
  835. // confirmButtonText: "OK",
  836. // confirmButtonClass: 'confirmBtn',
  837. // showCancelButton: false,
  838. // showClose: false,
  839. // type: "success",
  840. // center: true,
  841. // lockScroll: false,
  842. // }).then(() => {
  843. // });
  844. } else if (res.code == 10100) {
  845. this.$confirm(res.msg, {
  846. confirmButtonText: 'OK',
  847. showCancelButton: false,
  848. type: 'error',
  849. center: true
  850. });
  851. }
  852. }).catch(() => {
  853. this.closeDialog();
  854. });
  855. },
  856. regist() {
  857. this.submitLoading = true;
  858. const formData = Object.assign({}, this.registData);
  859. if (this.selectAddress && this.selectAddress.length) {
  860. formData.address = this.selectAddress;
  861. }
  862. this.$axios({
  863. url: '/uk-api/uk/register',
  864. method: 'post',
  865. data: formData
  866. }).then(res => {
  867. if (res.code == 1) {
  868. this.closeDialog();
  869. this.submitLoading = false;
  870. this.xxContentVisible = true;
  871. this.xxContent = "We've received your login request. Someone will be in touch shortly to confirm.";
  872. this.registerEmail();
  873. }
  874. }).catch(e => {
  875. const res = e.response.data;
  876. if (res.code === 10100) {
  877. this.$confirm(res.msg + ', please click OK to jump to login.', {
  878. confirmButtonText: 'OK',
  879. showCancelButton: false,
  880. type: 'error',
  881. center: true
  882. }).then(() => {
  883. this.submitLoading = false;
  884. this.activeName = 'first';
  885. });
  886. }
  887. });
  888. },
  889. registerEmail() {
  890. this.$axios.get('/uk-api/uk/register_email?email=' + this.registData.email).then(res => {}).catch(error => {
  891. this.$message.error(error.response.data.msg);
  892. });
  893. },
  894. close() {
  895. this.closeDialog();
  896. this.registData = {};
  897. },
  898. resetPassword() {
  899. this.closeDialog();
  900. this.$refs.resetPasswordDialog.resetDialogVisible = true;
  901. },
  902. openLoginDialog() {
  903. this.openDialog();
  904. },
  905. // 设置cookie
  906. setCookie(email, password, days) {
  907. const date = new Date();
  908. date.setTime(date.getTime() + 24 * 60 * 60 * 1000 * days);
  909. document.cookie = 'email' + '=' + email + ';path=/;expires=' + date.toGMTString();
  910. document.cookie = 'password' + '=' + password + ';path=/;expires=' + date.toGMTString();
  911. },
  912. // 读取cookie 将用户名和密码回显到input框中
  913. getCookie() {
  914. if (document.cookie.length > 0 && this.$cookies.get('can-use-cookie')) {
  915. const arr = document.cookie.split('; ');
  916. for (let i = 0; i < arr.length; i++) {
  917. const arr2 = arr[i].split('=');
  918. if (arr2[0] === 'email') {
  919. this.loginData.email = arr2[1];
  920. } else if (arr2[0] === 'password') {
  921. this.loginData.password = Base64.decode(arr2[1]);
  922. this.isRemember = true;
  923. }
  924. }
  925. }
  926. },
  927. toSignatureLink() {
  928. var _this$config$configIn;
  929. const link = ((_this$config$configIn = this.config.configInfo) === null || _this$config$configIn === void 0 ? void 0 : _this$config$configIn.link) || '';
  930. if (link) {
  931. window.open(link, '_blank');
  932. }
  933. },
  934. initGoogleMapAutoComplete() {
  935. // console.log(window.google.maps, 'maps')
  936. // https://developers.google.com/maps/documentation/javascript/place-autocomplete
  937. this.autoComplete = new window.google.maps.places.Autocomplete(document.getElementById('address_input'), {
  938. types: ['address'],
  939. componentRestrictions: {
  940. country: ['UK']
  941. },
  942. // 如果不知道需要什么字段, 可以查文档, 或给'all'或不传fields参数, 然后从返回结果里面找出需要数据的字段名, 填到这里
  943. fields: ['address_components', 'place_id', 'name', 'formatted_address']
  944. });
  945. this.autoComplete.addListener('place_changed', this.onPlaceChange);
  946. },
  947. onPlaceChange() {
  948. const data = this.autoComplete.getPlace();
  949. if (Array.isArray(data.address_components)) {
  950. data.address_components.forEach(i => {
  951. if (i.types.includes('postal_code')) {
  952. this.$set(this.registData, 'postcode', i.long_name || i.short_name);
  953. }
  954. if (i.types.includes('administrative_area_level_1')) {
  955. this.$set(this.registData, 'state', i.short_name || i.long_name);
  956. }
  957. });
  958. }
  959. this.selectAddress = data.name || this.registData.address;
  960. },
  961. onInputChange(value, attr) {
  962. if (attr === 'address') {
  963. // 地址输入变更时, 清空这个值, 避免手动输入地址又不选的时候, 这个变量保存了上一次选地址时留下的数据.
  964. this.selectAddress = '';
  965. }
  966. },
  967. getAddrByLocation() {
  968. if (navigator.geolocation) {
  969. let location = {
  970. lat: 0,
  971. lng: 0
  972. };
  973. navigator.geolocation.getCurrentPosition(position => {
  974. location = {
  975. lat: position.coords.latitude,
  976. lng: position.coords.longitude
  977. };
  978. console.log(location, 'position');
  979. const geocoder = new window.google.maps.Geocoder();
  980. geocoder.geocode({
  981. location
  982. }).then(response => {
  983. var _response$results;
  984. console.log(response, 'response');
  985. if ((_response$results = response.results) !== null && _response$results !== void 0 && _response$results.length) {
  986. response.results[0].address_components.forEach(i => {
  987. if (i.types.includes('postal_code')) {
  988. this.$set(this.registData, 'postcode', i.long_name || i.short_name);
  989. }
  990. if (i.types.includes('administrative_area_level_1')) {
  991. this.$set(this.registData, 'state', i.short_name || i.long_name);
  992. }
  993. if (i.types.includes('route')) {
  994. this.$set(this.registData, 'address', i.short_name || i.long_name);
  995. }
  996. this.selectAddress = i.short_name || i.long_name;
  997. });
  998. }
  999. });
  1000. }, error => {
  1001. console.log(error, 'get location error');
  1002. });
  1003. }
  1004. }
  1005. }
  1006. });
  1007. // CONCATENATED MODULE: ./components/loginDialog.vue?vue&type=script&lang=js
  1008. /* harmony default export */ var components_loginDialogvue_type_script_lang_js = (loginDialogvue_type_script_lang_js);
  1009. // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
  1010. var componentNormalizer = __webpack_require__(2);
  1011. // CONCATENATED MODULE: ./components/loginDialog.vue
  1012. function injectStyles (context) {
  1013. var style0 = __webpack_require__(338)
  1014. if (style0.__inject__) style0.__inject__(context)
  1015. }
  1016. /* normalize component */
  1017. var component = Object(componentNormalizer["a" /* default */])(
  1018. components_loginDialogvue_type_script_lang_js,
  1019. render,
  1020. staticRenderFns,
  1021. false,
  1022. injectStyles,
  1023. "0b8b973d",
  1024. "2a981bf3"
  1025. )
  1026. /* harmony default export */ var loginDialog = __webpack_exports__["default"] = (component.exports);
  1027. /***/ })
  1028. };;
  1029. //# sourceMappingURL=login-dialog.js.map