ChildForm.js 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622
  1. /**
  2. * Created by zhouy on 2018/10/18.
  3. */
  4. Ext.define('KitchenSink.view.binding.ChildForm', {
  5. extend: 'Ext.window.Window',
  6. xtype: 'document-kind-childwin',
  7. cls:'x-window-dbfind',
  8. layout: 'fit',
  9. modal: true,
  10. width: 500,
  11. //工具类
  12. height: 260,
  13. listeners:{
  14. show:function(w){
  15. if(w.record){
  16. w.down('form').loadRecord(w.record);
  17. }
  18. }
  19. },
  20. initComponent:function(){
  21. var me=this;
  22. Ext.apply(me,{
  23. items:me.setFormItems()
  24. });
  25. me.callParent();
  26. },
  27. etc:{
  28. customerkind:{
  29. items:[{
  30. xtype:'hidden',
  31. name:'id'
  32. },{
  33. xtype:'textfield',
  34. name:'ck_name',
  35. allowBlank:false,
  36. fieldLabel:'客户类型',
  37. maxLength: 20
  38. }]
  39. },
  40. vendorkind:{
  41. items:[{
  42. xtype:'hidden',
  43. name:'id'
  44. },{
  45. xtype:'textfield',
  46. name:'vk_name',
  47. allowBlank:false,
  48. fieldLabel:'供应商类型',
  49. maxLength: 20
  50. }]
  51. },
  52. productkind:{
  53. items:[{
  54. xtype:'hidden',
  55. name:'id'
  56. },{
  57. xtype:'textfield',
  58. name:'pt_name',
  59. allowBlank:false,
  60. fieldLabel:'物料类型',
  61. maxLength: 20
  62. }]
  63. },
  64. personpower:{
  65. items:[{
  66. xtype:'hidden',
  67. name:'id'
  68. },{
  69. xtype:'textfield',
  70. name:'name',
  71. allowBlank:false,
  72. fieldLabel:'角色名称',
  73. maxLength: 20
  74. },{
  75. xtype:'textfield',
  76. name:'description',
  77. allowBlank:false,
  78. fieldLabel:'角色描述',
  79. maxLength: 20
  80. },{
  81. xtype:'textfield',
  82. hidden:true,
  83. name:'code',
  84. allowBlank:true,
  85. fieldLabel:'角色编号',
  86. maxLength: 20
  87. }]
  88. },
  89. bankinformation:{
  90. items:[{
  91. xtype:'hidden',
  92. name:'id'
  93. },{
  94. xtype:'textfield',
  95. name:'bk_bankcode',
  96. allowBlank:false,
  97. fieldLabel:'账户编号',
  98. maxLength: 20
  99. },{
  100. xtype:'textfield',
  101. name:'bk_bankname',
  102. allowBlank:false,
  103. fieldLabel:'账户名称',
  104. maxLength: 20
  105. },{
  106. xtype:'numberfield',
  107. name:'bk_beginamount',
  108. allowBlank:false,
  109. fieldLabel:'期初金额',
  110. hideTrigger: true,
  111. mouseWheelEnabled: false,
  112. minValue: 0,
  113. maxLength:15,
  114. decimalPrecision:2,
  115. enforceMaxLength:true
  116. },
  117. // {
  118. // xtype:'numberfield',
  119. // name:'bk_thisamount',
  120. // allowBlank:true,
  121. // fieldLabel:'当前余额',
  122. // hideTrigger: true,
  123. // mouseWheelEnabled: false,
  124. // beforeLabelTextTpl:'',
  125. // minValue: 0
  126. // }
  127. // ,
  128. {
  129. xtype:'combo',
  130. name:'bk_type',
  131. allowBlank:false,
  132. editable:false,
  133. fieldLabel:'账户类别',
  134. store: [
  135. '现金',
  136. '银行'
  137. ]
  138. },{
  139. xtype:'datefield',
  140. name:'bk_date',
  141. fieldLabel:'建账日期',
  142. format:'Y-m-d H:i:s',
  143. listeners:{
  144. beforerender:function(d){
  145. d.setValue(new Date())
  146. }
  147. }
  148. }, {
  149. xtype:'textfield',
  150. name:'bk_remark',
  151. allowBlank:true,
  152. fieldLabel:'备注',
  153. beforeLabelTextTpl:''
  154. }]
  155. },
  156. productbrand:{
  157. items:[{
  158. xtype:'hidden',
  159. name:'id'
  160. },{
  161. xtype:'textfield',
  162. name:'pb_name',
  163. allowBlank:false,
  164. fieldLabel:'物料品牌',
  165. maxLength: 20
  166. }]
  167. },
  168. productunit:{
  169. items:[{
  170. xtype:'hidden',
  171. name:'id'
  172. },{
  173. xtype:'textfield',
  174. name:'pu_name',
  175. allowBlank:false,
  176. fieldLabel:'计量单位',
  177. maxLength: 20
  178. }]
  179. },
  180. inoutkind:{
  181. items:[{
  182. xtype:'hidden',
  183. name:'id'
  184. },{
  185. xtype:'textfield',
  186. name:'ft_name',
  187. allowBlank:false,
  188. fieldLabel:'收支名称',
  189. maxLength: 20
  190. },{
  191. xtype:'combo',
  192. name:'ft_kind',
  193. allowBlank:false,
  194. fieldLabel:'收支类型',
  195. hideTrigger : false,
  196. maxLength : 100.0,
  197. minValue : null,
  198. positiveNum : false,
  199. queryMode : "local",
  200. valueField : "value",
  201. xtype : "combo",
  202. editable:false,
  203. displayField : "display",
  204. store:{
  205. fields: ['display', 'value'],
  206. data : [
  207. {"display":"收入", "value":'收入'},
  208. {"display":"支出", "value":'支出'}
  209. ]
  210. }
  211. }]
  212. },
  213. address:{
  214. items:[{
  215. xtype:'hidden',
  216. name:'id'
  217. },{
  218. xtype:'textfield',
  219. name:'ad_address',
  220. allowBlank:false,
  221. fieldLabel:'地址详情',
  222. maxLength: 200
  223. }]
  224. },
  225. accountinformation:{
  226. items:[{
  227. xtype:'hidden',
  228. name:'accountId',
  229. hidden:true,
  230. },{
  231. xtype:'textfield',
  232. fieldLabel: '真实姓名',
  233. name: 'realname',
  234. readOnly:true,
  235. editable:false,
  236. allowBlank:true,
  237. maxLength: 30,
  238. beforeLabelTextTpl: "",
  239. },{
  240. xtype:'datamulticombo',
  241. dataUrl:'/api/account/role/list',
  242. fieldLabel: '关联角色',
  243. name: 'roleNames',
  244. allowBlank:true,
  245. maxLength: 20,
  246. beforeLabelTextTpl: "",
  247. },{
  248. xtype:'textfield',
  249. fieldLabel: '手机号码',
  250. name: 'mobile',
  251. readOnly:true,
  252. editable:false,
  253. allowBlank:true,
  254. maxLength: 30,
  255. beforeLabelTextTpl: "",
  256. },{
  257. xtype:'textfield',
  258. fieldLabel: '邮箱',
  259. name: 'email',
  260. readOnly:true,
  261. editable:false,
  262. allowBlank:true,
  263. maxLength: 30,
  264. beforeLabelTextTpl: "",
  265. }]
  266. },
  267. accountadd:{
  268. items:[{
  269. xtype:'textfield',
  270. fieldLabel: '手机号码',
  271. name: 'mobile',
  272. hideTrigger:true,
  273. allowBlank:false,
  274. maxLength: 30,
  275. regex:/^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$/,
  276. regexText:'请输入正确的手机号码',
  277. listeners:{
  278. blur:function(f,a,b,c){
  279. if(f.value&&f.value!=''&&f.isValid()){
  280. // var url = 'https://sso.ubtob.com' + '/api/user/checkMobile?mobile='+f.value;
  281. // saas.util.BaseUtil.request({url })
  282. // .then(function(res) {
  283. // if(res.success) {
  284. // }
  285. // })
  286. // .catch(function(response) {
  287. // });
  288. // Ext.Ajax.request({
  289. // url: Ext.manifest.server.accountPath + '/api/user/checkMobile',
  290. // params: {
  291. // mobile: f.value
  292. // },
  293. // method: 'GET',
  294. // headers:{
  295. // 'Access-Control-Allow-Origin': '*',
  296. // "Content-Type": 'application/json;charset=UTF-8'
  297. // },
  298. // success: function (response) {
  299. // debugger
  300. // },
  301. // failure: function (response) {
  302. // debugger
  303. // }
  304. // });
  305. }
  306. }
  307. }
  308. },{
  309. xtype:'textfield',
  310. fieldLabel: '真实姓名',
  311. name: 'realname',
  312. allowBlank:false,
  313. maxLength: 30,
  314. },{
  315. xtype:'textfield',
  316. fieldLabel: '邮箱',
  317. name: 'email',
  318. allowBlank:false,
  319. maxLength: 30,
  320. }]
  321. },
  322. warehouse:{
  323. items:[{
  324. xtype:'hidden',
  325. name:'id'
  326. },{
  327. xtype:'textfield',
  328. fieldLabel: '仓库编号',
  329. name: 'wh_code',
  330. allowBlank:false,
  331. maxLength: 20
  332. },{
  333. xtype:'textfield',
  334. fieldLabel: '仓库名称',
  335. name: 'wh_description',
  336. allowBlank:false,
  337. maxLength: 20
  338. },{
  339. xtype:'combo',
  340. fieldLabel: '仓库类型',
  341. name: 'wh_type',
  342. allowBlank:false,
  343. displayField : "display",
  344. editable:false,
  345. hideTrigger : false,
  346. maxLength : 100.0,
  347. minValue : null,
  348. positiveNum : false,
  349. queryMode : "local",
  350. valueField : "value",
  351. store:{
  352. fields: ['display', 'value'],
  353. data : [
  354. {"display":"良品仓", "value":'良品仓'},
  355. {"display":"不良品仓", "value":'不良品仓'}
  356. ]
  357. }
  358. },{
  359. readOnly:true,
  360. xtype:'textfield',
  361. fieldLabel: '仓库状态',
  362. name: 'wh_status',
  363. value:'已开启',
  364. maxLength: 20
  365. },{
  366. xtype:'hidden',
  367. fieldLabel: '仓库状态码',
  368. name: 'wh_statuscode',
  369. value:'OPEN'
  370. }]
  371. },
  372. employee:{
  373. items:[{
  374. xtype:'hidden',
  375. name:'id'
  376. },{
  377. xtype:'textfield',
  378. fieldLabel: '人员编号',
  379. name: 'em_code',
  380. allowBlank:false,
  381. maxLength: 20
  382. },{
  383. xtype:'textfield',
  384. fieldLabel: '人员名称',
  385. name: 'em_name',
  386. allowBlank:false,
  387. maxLength: 20
  388. },{
  389. xtype:'textfield',
  390. fieldLabel: '联系电话',
  391. name: 'em_mobile',
  392. allowBlank:true,
  393. beforeLabelTextTpl: '',
  394. maxLength: 20
  395. },{
  396. xtype:'textfield',
  397. fieldLabel: '邮箱',
  398. name: 'em_email',
  399. allowBlank:true,
  400. beforeLabelTextTpl: '',
  401. maxLength: 20
  402. },{
  403. value:'正式',
  404. xtype:'combo',
  405. fieldLabel: '人员状态',
  406. name: 'em_class',
  407. allowBlank:false,
  408. displayField : "display",
  409. editable:false,
  410. hideTrigger : false,
  411. maxLength : 100.0,
  412. minValue : null,
  413. positiveNum : false,
  414. queryMode : "local",
  415. valueField : "value",
  416. store:{
  417. fields: ['display', 'value'],
  418. data : [
  419. {"display":"正式", "value":'正式'},
  420. {"display":"离职", "value":'离职'}
  421. ]
  422. }
  423. },]
  424. },
  425. maxnumbers:{
  426. items:[{
  427. xtype:'hidden',
  428. name:'id'
  429. },{
  430. xtype:'textfield',
  431. fieldLabel: '单据名称',
  432. name: 'mn_name',
  433. allowBlank:false,
  434. editable:false,
  435. readOnly:true,
  436. maxLength: 20
  437. },{
  438. xtype:'textfield',
  439. fieldLabel: '单据前缀',
  440. name: 'mn_leadcode',
  441. beforeLabelTextTpl: '',
  442. allowBlank:true,
  443. maxLength: 20
  444. },{
  445. xtype:'combo',
  446. fieldLabel: '单据规则',
  447. name: 'mn_rule',
  448. displayField : "display",
  449. editable:false,
  450. hideTrigger : false,
  451. maxLength : 100.0,
  452. minValue : null,
  453. positiveNum : false,
  454. queryMode : "local",
  455. valueField : "value",
  456. store:{
  457. fields: ['display', 'value'],
  458. data : [
  459. {"display":"年月日", "value":'yyyymmdd'},
  460. {"display":"年月", "value":'yyyymm'},
  461. {"display":"无", "value":'无'}
  462. ]
  463. }
  464. },{
  465. xtype:'numberfield',
  466. hideTrigger : true,
  467. fieldLabel: '流水长度',
  468. name: 'mn_number',
  469. minValue : 0,
  470. allowBlank:false,
  471. mouseWheelEnabled: false
  472. }]
  473. }
  474. },
  475. setFormItems:function() {
  476. var me = this, kind = me.dataKind;
  477. var conf = {
  478. xtype: 'form',
  479. bodyPadding: 10,
  480. border: false,
  481. autoScroll:true,
  482. modelValidation: true,
  483. layout: {
  484. type: 'vbox',
  485. align: 'stretch'
  486. },
  487. defaults: {
  488. labelAlign:'right',
  489. beforeLabelTextTpl: "<font color=\"red\" style=\"position:relative; top:2px;right:2px; font-weight: bolder;\">*</font>",
  490. xtype: 'textfield'
  491. },
  492. buttons: [{
  493. text: '保存',
  494. formBind:true,
  495. handler: me.onSave,
  496. scope:me
  497. }, {
  498. text: '取消',
  499. handler: me.onCancel,
  500. scope:me
  501. }]
  502. };
  503. return Ext.apply(conf, me.etc[kind]);
  504. },
  505. onSave:function(){
  506. var me = this;
  507. var belong = this.belong;
  508. me.setLoading(true);
  509. var form=this.down('form');
  510. var combo = this._combo;
  511. var params = {};
  512. var names = belong.columns.map(column => column.dataIndex);
  513. //账户资料特殊保存逻辑
  514. if(me.dataKind=='accountinformation'){
  515. me.accountinformation();
  516. return;
  517. }
  518. Ext.Array.each(names,function(name) {
  519. if(name){
  520. var dataField = form.down('[name='+name+']');
  521. if(dataField&&dataField.value){
  522. params[name] = dataField.value;
  523. params._value = dataField.value;
  524. }
  525. }
  526. });
  527. var idField = form.down('[name='+belong.keyField+']');
  528. params[belong.keyField] = idField.value || 0;
  529. //保存接口
  530. saas.util.BaseUtil.request({
  531. url: belong.reqUrl,
  532. params: JSON.stringify(params),
  533. method: 'POST'
  534. })
  535. .then(function(localJson) {
  536. me.setLoading(false);
  537. if(localJson.success){
  538. var grid = form.ownerCt._parent ? form.ownerCt._parent.lookup('document-kind-Grid') : null;
  539. if(grid){
  540. grid.store.load();
  541. }
  542. if(combo){
  543. combo.store.load(function() {
  544. typeof combo.setValue == 'function' && combo.setValue(params._value);
  545. });
  546. }
  547. saas.util.BaseUtil.showSuccessToast('保存成功');
  548. form.ownerCt.close();
  549. }
  550. })
  551. .catch(function(res) {
  552. me.setLoading(false);
  553. console.error(res);
  554. saas.util.BaseUtil.showErrorToast('保存失败: ' + res.message);
  555. });
  556. },
  557. onCancel:function(){
  558. this.hide();
  559. },
  560. accountinformation:function(){
  561. var me = this;
  562. var belong = this.belong;
  563. me.setLoading(true);
  564. var form=this.down('form');
  565. var combo = this._combo;
  566. var params = {};
  567. var names = belong.columns.map(column => column.dataIndex);
  568. Ext.Array.each(names,function(name) {
  569. if(name){
  570. var dataField = form.down('[name='+name+']');
  571. if(dataField&&dataField.value){
  572. params[name] = dataField.value;
  573. params._value = dataField.value;
  574. }
  575. }
  576. });
  577. //更改参数
  578. var o = '';
  579. Ext.Array.each(params.roleNames,function(item) {
  580. o+=item.value+','
  581. });
  582. o = o.substring(0,o.length-1);
  583. if(o==""){
  584. saas.util.BaseUtil.showErrorToast('关联角色未选择,无法保存!')
  585. }
  586. var _params = {
  587. accountId:Number(params['accountId']),
  588. roleIds:o,
  589. };
  590. //保存接口
  591. saas.util.BaseUtil.request({
  592. url: belong.reqUrl,
  593. params: _params,
  594. method: 'POST',
  595. headers:{
  596. 'Access-Control-Allow-Origin': '*',
  597. "Content-Type":'application/x-www-form-urlencoded'
  598. }
  599. })
  600. .then(function(localJson) {
  601. me.setLoading(false);
  602. if(localJson.success){
  603. saas.util.BaseUtil.showSuccessToast('保存成功');
  604. form.ownerCt._parent.store.load()
  605. form.ownerCt.close();
  606. }
  607. })
  608. .catch(function(res) {
  609. me.setLoading(false);
  610. console.error(res);
  611. saas.util.BaseUtil.showErrorToast('保存失败: ' + res.message);
  612. });
  613. }
  614. });