__vue_app_object.js 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576
  1. /*
  2. * Core js fw functions
  3. * Do not edit this file
  4. */
  5. /*
  6. * Default Vue App object
  7. */
  8. var mgDefauleVueObject = {
  9. el: null,//'#'+controlerId,
  10. data: {
  11. targetId : null,//controlerId,
  12. targetUrl : null, //mgUrlParser.getCurrentUrl(),
  13. pageLoading : false,
  14. returnedData : null,
  15. loading : false,
  16. loaderComponent : '<div class="row"><i class="dataTables_processing"></i></div>',
  17. sSearch : null,
  18. showModal : false,
  19. htmlContent : '',
  20. modalBodyContainer : 'mg-modal-body',
  21. refreshingState : [],
  22. massActionIds : null,
  23. massActionTargetCont : null,
  24. pagePreLoader : null,
  25. destroyComponent: false,
  26. modalInstance : null,
  27. mgNewModalContainerName: 'mg-component-body-empty-modal',
  28. mgNewModalJsObj: null,
  29. mgNewModalvIf: false,
  30. appActionBlockingState: false
  31. },
  32. created: function () {
  33. var self = this;
  34. self.$on('restartRefreshingState', self.cleanRefreshActionsState());
  35. self.$nextTick(function(){
  36. initContainerSelects('layers');
  37. });
  38. mgEventHandler.runCallback('AppCreated', self.targetId, {instance: self});
  39. },
  40. methods: {
  41. selectChangeAction : function($event) {
  42. mgEventHandler.runCallback('SelectFieldValueChanged', $event.target.name, {data: $event.target});
  43. },
  44. rendKey: function (lenth) {
  45. if (!lenth) {
  46. lenth = 6;
  47. }
  48. var randKey = "";
  49. var avChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
  50. for (var i = 0; i < lenth; i++) {
  51. randKey += avChars.charAt(Math.floor(Math.random() * avChars.length));
  52. }
  53. return randKey;
  54. },
  55. vloadData : function (params, forceRawData) {
  56. var self = this;
  57. var returnType = forceRawData ? 'text' : 'json';
  58. self.refreshUrl();
  59. for(var propertyName in params) {
  60. self.addUrlComponent(propertyName, params[propertyName]);
  61. }
  62. self.addUrlComponent('ajax', '1');
  63. return $.get(self.targetUrl, function(data){
  64. if (!forceRawData) {
  65. data = data.data;
  66. if (data.callBackFunction && typeof window[data.callBackFunction] === "function") {
  67. window[data.callBackFunction](data);
  68. }
  69. }
  70. }, returnType).fail(function(jqXHR, textStatus, errorThrown) {
  71. //self.addAlert('danger', 'Action Failed');
  72. console.log('Action Failed');
  73. });
  74. },
  75. addUrlComponent : function($name, $value) {
  76. var self = this;
  77. if (typeof $value === 'object') {
  78. for (var key in $value) {
  79. if (!$value.hasOwnProperty(key)) {
  80. continue;
  81. }
  82. self.targetUrl += (self.targetUrl.indexOf('?') !== -1 ? '&' : '?') + $name + '[' + key + ']' + '=' + encodeURIComponent($value[key]);
  83. }
  84. } else{
  85. self.targetUrl += (self.targetUrl.indexOf('?') !== -1 ? '&' : '?') + $name + '=' + encodeURIComponent($value);
  86. }
  87. },
  88. updateUrlParam : function(key, value, event){
  89. var self = this;
  90. value = self.updateValueByAttrs(key, value, event);
  91. if(self.targetUrl.indexOf(key) === -1){
  92. self.addUrlComponent(key, value);
  93. } else {
  94. var baseUrlParts = self.targetUrl.split('?');
  95. var currentUrlParams = baseUrlParts[1].split('&');
  96. for(i=0; i < currentUrlParams.length; i++){
  97. if(currentUrlParams[i].indexOf(key) === 0){
  98. if(value === ''){
  99. currentUrlParams.splice(i, 1);
  100. } else {
  101. currentUrlParams[i] = key + '=' + value;
  102. }
  103. }
  104. }
  105. var updatedUrlParams = currentUrlParams.join('&');
  106. self.targetUrl = baseUrlParts[0] + '?' + updatedUrlParams;
  107. }
  108. },
  109. updateValueByAttrs : function(key, value, event){
  110. if(value.indexOf(':') !== 0){
  111. return value;
  112. } else {
  113. if($(event.target).attr('data-' + key)) {
  114. return $(event.target).attr('data-' + key);
  115. } else if( $(event.target).parents('a').first().attr('data-' + key)) {
  116. return $(event.target).parents('a').first().attr('data-' + key);
  117. } else if( $(event.target).parents('button').first().attr('data-' + key)) {
  118. return $(event.target).parents('button').first().attr('data-' + key);
  119. } else {
  120. return value;
  121. }
  122. }
  123. },
  124. refreshUrl : function() {
  125. var self = this;
  126. self.targetUrl = mgUrlParser.getCurrentUrl();
  127. if(self.targetUrl.indexOf('#') > 0) {
  128. self.targetUrl = self.targetUrl.substr(0, self.targetUrl.indexOf('#'));
  129. }
  130. },
  131. loadModal : function(event, targetId, namespace, index, params, addSpinner){
  132. event.preventDefault();
  133. event.stopImmediatePropagation();
  134. var self = this;
  135. if (self.appActionBlockingState) {
  136. return true;
  137. }
  138. self.appActionBlockingState = true;
  139. self.htmlContent = '<div></div>';
  140. if (addSpinner) {
  141. self.showSpinner(event);
  142. }
  143. self.refreshUrl();
  144. self.initRefreshActions(event, targetId);
  145. self.initMassActions(event);
  146. self.addUrlComponent('loadData', targetId);
  147. self.addUrlComponent('namespace', namespace);
  148. if (params && params.length > 0)
  149. {
  150. for (i = 0; i < params.length; i++) {
  151. self.addUrlComponent(params[i].name, params[i].value);
  152. }
  153. }
  154. self.addUrlComponent('index', index);
  155. self.addUrlComponent('mgformtype', 'read');
  156. self.getActionId(event);
  157. self.addUrlComponent('ajax', '1');
  158. var request = $.get(self.targetUrl, function(data){
  159. data = data.data;
  160. if(data.status === 'success'){
  161. self.htmlContent = data.rawData.htmlData;
  162. mgPageControler.initModal(targetId, namespace, index, event, data.rawData);
  163. } else {
  164. self.handleErrorMessage(data);
  165. mgEventHandler.runCallback('ModalLoadFailed', targetId, {respData: data});
  166. }
  167. self.$nextTick(function() {
  168. if (data.callBackFunction && typeof window[data.callBackFunction] === "function") {
  169. window[data.callBackFunction](data, targetId, event);
  170. }
  171. });
  172. if (addSpinner) {
  173. self.hideSpinner(event);
  174. }
  175. self.appActionBlockingState = false;
  176. }, 'json').fail(function(jqXHR, textStatus, errorThrown) {
  177. if (addSpinner) {
  178. self.hideSpinner(event);
  179. }
  180. self.appActionBlockingState = false;
  181. self.handleServerError(jqXHR, textStatus, errorThrown);
  182. mgEventHandler.runCallback('ModalLoadFailed', targetId, {jqXHR : jqXHR, textStatus: textStatus, errorThrown: errorThrown});
  183. });
  184. self.refreshUrl();
  185. return request;
  186. },
  187. showSpinner : function(event) {
  188. var self = this;
  189. var spinnerTarget = self.getSpinerTarget(event);
  190. if (spinnerTarget && spinnerTarget.length > 0 || $(spinnerTarget).tagName === 'I') {
  191. var isBtnIcon = $(spinnerTarget).hasClass('lu-btn__icon');
  192. $(spinnerTarget).attr('originall-button-icon', $(spinnerTarget).attr('class'));
  193. $(spinnerTarget).removeAttr('class');
  194. $(spinnerTarget).attr('class', (isBtnIcon ? 'lu-btn__icon ' : '') + 'lu-btn__icon lu-preloader lu-preloader--sm');
  195. } else {
  196. self.addSpinner(event);
  197. }
  198. },
  199. reloadModalContent: function(event, targetId, namespace, index, params, addSpinner) {
  200. var self = this;
  201. $('#mgModalContainer').append('<div class="preloader-container preloader-container--full-screen preloader-container--overlay" v-show="loading"><div class="preloader preloader--sm"></div></div>');
  202. self.refreshUrl();
  203. self.initRefreshActions(event, targetId);
  204. self.initMassActions(targetId);
  205. self.addUrlComponent('loadData', targetId);
  206. self.addUrlComponent('namespace', namespace);
  207. self.addUrlComponent('index', index);
  208. self.addUrlComponent('mgformtype', 'reload');
  209. self.getActionId(event);
  210. self.addUrlComponent('ajax', '1');
  211. var formData =[];
  212. if($('#mgModalContainer').find('form').length > 0) {
  213. var formTargetId = $('#mgModalContainer').find('form').first().attr('id');
  214. var formCont = new mgFormControler(formTargetId);
  215. var formData = formCont.getFieldsData();
  216. }
  217. $.ajax({
  218. type: "POST",
  219. url: self.targetUrl,
  220. data: formData,
  221. processData: false,
  222. contentType: false
  223. }).done(function (data) {
  224. data = data.data;
  225. if(data.status === 'success'){
  226. self.htmlContent = data.rawData.htmlData;
  227. self.destroyComponent = true;
  228. mgPageControler.initModal(targetId, namespace, index, event, data.rawData);
  229. } else {
  230. self.handleErrorMessage(data);
  231. $('#mgModalContainer #mg-full-modal-wrapper').remove();
  232. }
  233. self.$nextTick(function() {
  234. if (data.callBackFunction && typeof window[data.callBackFunction] === "function") {
  235. window[data.callBackFunction](data, targetId, event);
  236. }
  237. });
  238. }).fail(function() {
  239. //self.addAlert('danger', 'Action Failed');
  240. console.log('Action Failed');
  241. });
  242. self.refreshUrl();
  243. },
  244. hideSpinner : function(event) {
  245. var self = this;
  246. var spinnerTarget = self.getSpinerTarget(event);
  247. if ($(event.target).attr('originall-button-content')) {
  248. self.removeSpinner(event);
  249. } else if (spinnerTarget && spinnerTarget.length > 0 || $(spinnerTarget).tagName === 'I') {
  250. $(spinnerTarget).removeAttr('class');
  251. $(spinnerTarget).attr('class', $(spinnerTarget).attr('originall-button-icon'));
  252. $(spinnerTarget).removeAttr('originall-button-icon');
  253. }
  254. },
  255. removeSpinner : function(event) {
  256. $(event.target).html($(event.target).attr('originall-button-content'));
  257. $(event.target).removeAttr('originall-button-content');
  258. },
  259. addSpinner : function(event) {
  260. var elWidth = $(event.target).width();
  261. var spinnerClass = $(event.target).hasClass('lu-btn--success') ? 'lu-preloader-success' : ($(event.target).hasClass('lu-btn--danger') ? 'lu-preloader-danger' : '');
  262. $(event.target).attr('originall-button-content', $(event.target).html());
  263. $(event.target).html('<span class="lu-btn__icon lu-temp-button-loader" style="margin: 0 0 0 0 !important; width: ' + elWidth + 'px;"><i class="lu-btn__icon lu-preloader lu-preloader--sm ' + spinnerClass + '"></i></span>');
  264. },
  265. getSpinerParent : function(event) {
  266. if($(event.target)[0].tagName === 'A' || $(event.target)[0].tagName === 'BUTTON'){
  267. return $(event.target)[0];
  268. } else if($(event.target)[0].parents('button').first()){
  269. return $(event.target)[0].parents('button').first();
  270. } else if($(event.target)[0].parents('a').first()){
  271. return $(event.target)[0].parents('a').first();
  272. } else {
  273. return null;
  274. }
  275. },
  276. getSpinerTarget : function(event) {
  277. if($(event.target)[0].tagName === 'I'){
  278. return $(event.target);
  279. } else if($(event.target)[0].tagName === 'SPAN'){
  280. var aParents = $(event.target).parents('a');
  281. return aParents.length === 0 ? $(event.target).parents('button').first().find('i').first() : $(event.target).parents('a').first().find('i').first();
  282. } else if($(event.target)[0].tagName === 'A'){
  283. return $(event.target).find('i').first();
  284. } else if($(event.target)[0].tagName === 'BUTTON'){
  285. return $(event.target).find('i').first();
  286. } else {
  287. return null;
  288. }
  289. },
  290. initMassActions : function(event){
  291. var self = this;
  292. self.cleanMassActions();
  293. if($(event.target).parents('.lu-t-c__mass-actions').length === 0)
  294. {
  295. return;
  296. }
  297. self.addUrlComponent('isMassAction', '1');
  298. var tableContainer = $(event.target).parents('.vueDatatableTable').first().attr('id');
  299. self.massActionTargetCont = tableContainer;
  300. self.massActionIds = collectTableMassActionsData(tableContainer);
  301. },
  302. addMassActionsToData : function (formData){
  303. var self = this;
  304. if(self.massActionIds){
  305. for (var key in self.massActionIds) {
  306. if (!self.massActionIds.hasOwnProperty(key)) {
  307. continue;
  308. }
  309. formData.set('massActions[' + key + ']', self.massActionIds[key]);
  310. }
  311. return formData;
  312. }else{
  313. return formData;
  314. }
  315. },
  316. cleanMassActions : function(){
  317. var self = this;
  318. if(self.massActionIds || self.massActionTargetCont){
  319. self.massActionIds = null;
  320. //uncheckSelectAllCheck(self.massActionTargetCont);
  321. self.$nextTick(function() {
  322. self.massActionTargetCont = null;
  323. });
  324. }
  325. },
  326. addRefreshActions: function (targetId) {
  327. var self = this;
  328. self.refreshingState.push(targetId);
  329. },
  330. initRefreshActions : function(event, targetId) {
  331. var self = this;
  332. var menuReloading = ['addGroupButton', 'editGroupButton', 'deleteGroupButton'];
  333. if(menuReloading.indexOf(targetId) > -1)
  334. {
  335. self.refreshingState = ['mg-category-menu'];
  336. return;
  337. }
  338. var tableContainer = $(event.target).parents('.vueDatatableTable').first();
  339. self.refreshingState = [$(tableContainer).attr('id')];
  340. },
  341. runRefreshActions : function(ids, data) {
  342. var self = this;
  343. var rfIds = (ids && ids.length > 0) ? ids : self.refreshingState;
  344. var customParams = (data && typeof data.customParams !== undefined) ? data.customParams : null;
  345. if(rfIds && rfIds.length > 0){
  346. $.each(rfIds, function (index, Id) {
  347. var targetId = Id;
  348. self.$nextTick(function() {
  349. self.$emit('reloadMgData', targetId, customParams);
  350. });
  351. });
  352. }
  353. },
  354. cleanRefreshActionsState : function() {
  355. var self = this;
  356. self.refreshingState = [];
  357. },
  358. getActionId : function(event) {
  359. var self = this;
  360. var tableActions = $(event.target).parents("td.mgTableActions");
  361. var widgetActionComponent = $(event.target).parents("div.widgetActionComponent");
  362. if($(tableActions).length === 1){
  363. var row = $(tableActions[0]).parent('tr');
  364. var actionElementId = $(row).attr("actionid");
  365. if(actionElementId){
  366. self.addUrlComponent('actionElementId', actionElementId);
  367. }
  368. } else if(widgetActionComponent.length === 1){
  369. var actionElementId = widgetActionComponent.first().attr("actionid");
  370. if(actionElementId){
  371. self.addUrlComponent('actionElementId', actionElementId);
  372. }
  373. }
  374. },
  375. submitForm : function(targetId, event) {
  376. event.preventDefault();
  377. var self = this;
  378. if (self.appActionBlockingState) {
  379. return true;
  380. }
  381. self.appActionBlockingState = true;
  382. var formTargetId = ($('#'+targetId)[0].tagName === 'FORM') ? targetId : $('#'+targetId).find('form').attr('id');
  383. if(formTargetId){
  384. self.showSpinner(event);
  385. var formCont = new mgFormControler(formTargetId);
  386. var formData = formCont.getFieldsData();
  387. formData = self.addMassActionsToData(formData);
  388. self.refreshUrl();
  389. self.addUrlComponent('loadData', formTargetId);
  390. self.addUrlComponent('namespace', getItemNamespace(formTargetId));
  391. self.addUrlComponent('index', getItemIndex(formTargetId));
  392. self.addUrlComponent('ajax', '1');
  393. self.addUrlComponent('mgformtype', $('#'+formTargetId).attr('mgformtype'));
  394. $.ajax({
  395. type: "POST",
  396. url: self.targetUrl,
  397. data: formData,
  398. processData: false,
  399. contentType: false})
  400. .done(function( data ) {
  401. data = data.data;
  402. self.hideSpinner(event);
  403. self.$nextTick(function() {
  404. if (data.callBackFunction && typeof window[data.callBackFunction] === "function") {
  405. window[data.callBackFunction](data, targetId, event);
  406. }
  407. });
  408. if(data.status === 'success'){
  409. self.showModal = false;
  410. self.runRefreshActions((data && typeof data.refreshIds !== undefined) ? data.refreshIds : null, data);
  411. self.cleanMassActions();
  412. self.addAlert(data.status, data.message);
  413. formCont.updateFieldsValidationMessages([]);
  414. } else if (data.rawData !== undefined && data.rawData.FormValidationErrors !== undefined) {
  415. formCont.updateFieldsValidationMessages(data.rawData.FormValidationErrors);
  416. } else {
  417. formCont.updateFieldsValidationMessages([]);
  418. self.handleErrorMessage(data);
  419. }
  420. self.appActionBlockingState = false;
  421. }).fail(function(jqXHR, textStatus, errorThrown) {
  422. self.hideSpinner(event);
  423. self.handleServerError(jqXHR, textStatus, errorThrown);
  424. self.appActionBlockingState = false;
  425. });
  426. }
  427. else {
  428. //todo error reporting
  429. }
  430. },
  431. handleErrorMessage: function(data) {
  432. var self = this;
  433. self.addAlert(data.status,(data.message ? data.message : (typeof data.data !== 'undefined' ?
  434. ((typeof data.data.errorCode !== 'undefined' ? 'Error Code: ' + data.data.errorCode + ' <br> ' : '')
  435. + (typeof data.data.errorToken !== 'undefined' ? 'Error Token: ' + data.data.errorToken + ' <br> ' : '')
  436. + (typeof data.data.errorTime !== 'undefined' ? 'Error Time: ' + data.data.errorTime + ' <br> ' : '')
  437. + (typeof data.data.errorMessage !== 'undefined' ? 'Message: ' + data.data.errorMessage : '')) : '')
  438. ));
  439. if ((typeof data.data !== 'undefined') && (typeof data.data.errorCode !== 'undefined'))
  440. {
  441. console.log(data.data);
  442. }
  443. },
  444. handleServerError: function(jqXHR, textStatus, errorThrown) {
  445. var self = this;
  446. if (jqXHR.responseText.indexOf('id="mg-sh-h-492318-64534" value="') > 0){
  447. var errTokenStart = jqXHR.responseText.indexOf('mg-sh-h-492318-64534') + 20;
  448. var errTokenEnd = jqXHR.responseText.indexOf('mg-sh-h-492318-64534-end');
  449. var errToken = jqXHR.responseText.substr(errTokenStart, (errTokenEnd - errTokenStart));
  450. errToken = errToken.replace('value=', '').replace(/\"/g, '').replace(/\s/g, '');
  451. self.addAlert('error', 'Unexpected Error. <br>Error Token: ' + errToken);
  452. console.log('Action Failed. Error Token: ' + errToken);
  453. } else {
  454. console.log('Action Failed');
  455. }
  456. },
  457. ajaxAction : function(event, targetId, namespace, index, postData, addSpinner=false) {
  458. var self = this;
  459. self.refreshUrl();
  460. self.initRefreshActions(event, targetId);
  461. self.addUrlComponent('loadData', targetId);
  462. self.addUrlComponent('namespace', namespace);
  463. self.addUrlComponent('index', index);
  464. self.getActionId(event);
  465. self.addUrlComponent('ajax', '1');
  466. if (addSpinner) {
  467. self.showSpinner(event);
  468. }
  469. $.post(self.targetUrl, postData)
  470. .done(function( data ) {
  471. if (addSpinner) {
  472. self.hideSpinner(event);
  473. }
  474. data = data.data;
  475. self.addAlert(data.status, data.message);
  476. self.$nextTick(function() {
  477. if (data.callBackFunction && typeof window[data.callBackFunction] === "function") {
  478. window[data.callBackFunction](data, targetId, event);
  479. }
  480. });
  481. if(data.status === 'success' && data.refreshIds !== undefined){
  482. self.runRefreshActions((data && typeof data.refreshIds !== undefined) ? data.refreshIds : null, data);
  483. }
  484. }, 'json');
  485. self.refreshUrl();
  486. },
  487. updateSorting : function(order, loadData, namespace)
  488. {
  489. var self = this;
  490. self.refreshUrl();
  491. self.addUrlComponent('loadData', loadData);
  492. self.addUrlComponent('namespace', namespace);
  493. self.addUrlComponent('ajax', '1');
  494. self.addUrlComponent('mgformtype', "reorder");
  495. var formData = {order : order}
  496. $.post(self.targetUrl, {formData: formData}).done(function( data )
  497. {
  498. data = data.data;
  499. self.addAlert(data.status, data.message);
  500. self.pageLoading = false;
  501. self.$nextTick(function() {
  502. if (data.callBackFunction && typeof window[data.callBackFunction] === "function") {
  503. window[data.callBackFunction](data, loadData);
  504. }
  505. });
  506. if(data.status === 'success')
  507. {
  508. //Dispaly alert?
  509. }
  510. else
  511. {
  512. //TODO: Dispaly alert
  513. }
  514. });
  515. },
  516. addAlert : function(type, message){
  517. type = (type === 'error') ? 'danger' : type;
  518. layers.alert.create({
  519. $alertPosition: 'right-top',
  520. $alertStatus: type,
  521. $alertBody: message,
  522. $alertTimeout: 10000
  523. });
  524. },
  525. makeCustomAction : function(functionName, params, event, namespace, index) {
  526. var self = this;
  527. if (functionName && typeof mgPageControler.vueLoader[functionName] === "function") {
  528. mgPageControler.vueLoader[functionName](self, params, event, namespace, index);
  529. } else if (functionName && typeof window[functionName] === "function") {
  530. window[functionName](self, params, event, namespace, index);
  531. }
  532. },
  533. redirect : function (event, params, targetBlank) {
  534. var self = this;
  535. var tempUrl = self.targetUrl;
  536. if(params.rawUrl !== undefined){
  537. self.targetUrl = params.rawUrl;
  538. }
  539. if(params.actionElementId !== undefined) {
  540. self.getActionId(event);
  541. }
  542. $.each(params, function(key, value){
  543. if(key === 'rawUrl' || key === 'actionElementId'){
  544. return false;
  545. } else {
  546. self.updateUrlParam(key.replace('__', '-'), value, event);
  547. }
  548. });
  549. if (targetBlank) {
  550. window.open(self.targetUrl, '_blank');
  551. } else {
  552. window.location = self.targetUrl;
  553. }
  554. },
  555. submitFormByEvent : function(event){
  556. var self = this;
  557. self.submitForm($(event.target).parents("form").first().attr('id'), event);
  558. },
  559. submitFormByField: function(event) {
  560. }
  561. }
  562. };