FormPanel.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488
  1. Ext.define('saas.view.sys.config.FormPanel', {
  2. extend: 'Ext.form.Panel',
  3. xtype: 'sys-config-formpanel',
  4. controller: 'sys-config-formpanel',
  5. viewModel: 'sys-config-formpanel',
  6. //字段属性
  7. _idField: 'id',
  8. _readUrl:'http://192.168.253.31:8560/api/account/company/read/current',
  9. _saveUrl:'http://192.168.253.31:8560/api/account/company/save',
  10. //基础属性
  11. frame:true,
  12. initId: 0,
  13. layout: 'vbox',
  14. autoScroll: true,
  15. border: 1,
  16. bodyPadding: 5,
  17. fieldDefaults: {
  18. margin: '0 5 5 30',
  19. labelAlign: 'right',
  20. labelWidth: 90,
  21. width:300,
  22. blankText: '该字段不能为空'
  23. },
  24. bbar:{
  25. frame:true,
  26. items:['->',{
  27. text:'保存',
  28. formBind:true,
  29. name:'save'
  30. },'->']
  31. },
  32. items: [{
  33. bind:'{id}',
  34. xtype: 'hidden',
  35. name: 'id',
  36. fieldLabel: 'id',
  37. allowBlank: true,
  38. width:600
  39. },{
  40. bind:'{name}',
  41. xtype: 'textfield',
  42. name: 'name',
  43. fieldLabel: '公司名称',
  44. allowBlank: true,
  45. editable:false,
  46. readOnly:true,
  47. width:600
  48. },{
  49. bind:'{address}',
  50. xtype: 'textfield',
  51. name: 'address',
  52. fieldLabel: '公司地址',
  53. beforeLabelTextTpl : "<font color=\"red\" style=\"position:relative; top:2px;right:2px; font-weight: bolder;\">*</font>",
  54. allowBlank: false,
  55. width:600
  56. },{
  57. bind:'{tel}',
  58. xtype: 'textfield',
  59. name: 'tel',
  60. fieldLabel: '电话',
  61. beforeLabelTextTpl : "<font color=\"red\" style=\"position:relative; top:2px;right:2px; font-weight: bolder;\">*</font>",
  62. allowBlank: false,
  63. width:500
  64. },{
  65. bind:'{fax}',
  66. xtype: 'textfield',
  67. name: 'fax',
  68. fieldLabel: '传真',
  69. allowBlank: true,
  70. width:500
  71. }
  72. // ,{
  73. // bind:'{en_begindate}',
  74. // xtype : "datefield",
  75. // name : "en_begindate",
  76. // format:'Y-m-d H:i:s',
  77. // fieldLabel : "开账日期",
  78. // allowBlank : true,
  79. // editable:false,
  80. // hideTrigger:true,
  81. // readOnly:true,
  82. // width:500
  83. // }
  84. // ,{
  85. // bind:'{en_pricemethod}',
  86. // displayField : "display",
  87. // editable:false,
  88. // hideTrigger : false,
  89. // maxLength : 100.0,
  90. // width:500,
  91. // minValue : null,
  92. // queryMode : "local",
  93. // valueField : "value",
  94. // xtype : "combo",
  95. // value:'WACC',
  96. // store:{
  97. // fields: ['display', 'value'],
  98. // data : [
  99. // {"display":"加权平均法", "value":'WACC'},
  100. // {"display":"先进先出法", "value":'FIFO'}
  101. // ]
  102. // },
  103. // name : "en_pricemethod",
  104. // beforeLabelTextTpl : "<font color=\"red\" style=\"position:relative; top:2px;right:2px; font-weight: bolder;\">*</font>",
  105. // fieldLabel : "库存计算方式",
  106. // allowBlank : false,
  107. // }
  108. // ,{
  109. // ignore:true,
  110. // bind:'{updateTime}',
  111. // xtype : "datefield",
  112. // name : "updateTime",
  113. // fieldLabel : "更新时间",
  114. // allowBlank : true,
  115. // hideTrigger:true,
  116. // format:'Y-m-d H:i:s',
  117. // editable:false,
  118. // readOnly:true,
  119. // width:500,
  120. // }
  121. ,{
  122. xtype: 'form',
  123. width:600,
  124. frame: false,
  125. border: false,
  126. minHeight: 22,
  127. bodyStyle: 'padding:2px;',
  128. layout: 'vbox',
  129. items:[{
  130. bind:'{signet}',
  131. name : "signet",
  132. allowBlank : true,
  133. hidden:true,
  134. xtype:'textfield'
  135. },{
  136. allowBlank : true,
  137. width:500,
  138. fieldLabel:'打印章上传',
  139. xtype: 'filefield',
  140. name:'signetFilefield',
  141. emptyText: '请选择图片',
  142. buttonText: '',
  143. buttonConfig: {
  144. iconCls: 'x-fa fa-picture-o',
  145. },
  146. createFileInput : function() {
  147. var me = this;
  148. me.fileInputEl = me.button.el.createChild({
  149. name: me.getName(),
  150. cls: Ext.baseCSSPrefix + 'form-file-input',
  151. tag: 'input',
  152. type: 'file',
  153. size: 1,
  154. accept:"image/*"
  155. }).on('change', me.onFileChange, me);
  156. },
  157. listeners: {
  158. afterrender:function(field,ops){
  159. var fileEl = field.fileInputEl.dom;
  160. fileEl.setAttribute("accept","image/*");
  161. },
  162. change: function(field){
  163. var form = field.ownerCt.ownerCt;
  164. var myForm = field.ownerCt;
  165. var fileEl = field.fileInputEl.dom;
  166. var fd = new FormData();
  167. fd.append('file', fileEl.files[0]);
  168. form.setLoading(true);
  169. Ext.Ajax.request({
  170. url: 'http://192.168.253.31:8560/api/file/upload',//这里是填写需要跨域访问的URL
  171. cors: true,
  172. useDefaultXhrHeader: false,
  173. method: 'post',
  174. rawData: fd,
  175. headers: {
  176. 'Access-Control-Allow-Origin': '*',
  177. 'Authorization': saas.util.State.get('session').token,
  178. //"Content-Type": 'multipart/form-data' //文件上传的格式,
  179. "Content-Type":null
  180. },
  181. success: function (response, opts) {
  182. saas.util.BaseUtil.showToast('上传成功');
  183. var res = Ext.decode(response.responseText);
  184. if(res.success){
  185. var data = res.data;
  186. var name = data.name + " (" + Ext.util.Format.fileSize(data.size) + ")";
  187. myForm.down('[name=signet]').setValue(data.fullPath);
  188. field.setRawValue(name);
  189. //读取图片
  190. if(data.id){
  191. var img = myForm.down('[name=SignetPhoto]');
  192. img.el.dom.src = 'http://192.168.253.31:8560/api/file/download?path='+data.fullPath;
  193. var showSignetPhoto = form.down('[name=showSignetPhoto]');
  194. showSignetPhoto.show();
  195. }
  196. }else{
  197. saas.util.BaseUtil.showToast('上传失败: ' + res.message);
  198. }
  199. form.setLoading(false);
  200. },
  201. failure: function (response, opts) {
  202. form.setLoading(false);
  203. var res = Ext.decode(response.responseText);
  204. saas.util.BaseUtil.showToast('上传失败: ' + res.message);
  205. }
  206. });
  207. }
  208. }
  209. },{
  210. xtype: 'image',
  211. width: 100,
  212. height: 100,
  213. margin:'5 0 5 150',
  214. src:'resources/images/default/basePhoto.png',
  215. name:'SignetPhoto',
  216. },{
  217. margin:'0 0 5 151',
  218. xtype:'container',
  219. name:'showSignetPhoto',
  220. cls:'x-container-group',
  221. hidden:true,
  222. items:[{
  223. width: 45,
  224. height: 24,
  225. xtype:'button',
  226. text:'查看',
  227. handler:function(b){
  228. var form = b.ownerCt.ownerCt.ownerCt;
  229. var img = form.down('[name=SignetPhoto]');
  230. form.lookPic(img);
  231. }
  232. },{
  233. margin:'0 0 0 10',
  234. width: 45,
  235. height: 24,
  236. xtype:'button',
  237. text:'下载',
  238. handler:function(b){
  239. var form = b.ownerCt.ownerCt.ownerCt;
  240. var path = form.down('[name=signet]').value;
  241. form.downLoad(path);
  242. }
  243. }]
  244. }]
  245. },{
  246. xtype: 'form',
  247. width:600,
  248. frame: false,
  249. border: false,
  250. minHeight: 22,
  251. bodyStyle: 'padding:2px;',
  252. layout: 'vbox',
  253. items:[{
  254. bind:'{logoUrl}',
  255. name : "logoUrl",
  256. allowBlank : true,
  257. hidden:true,
  258. xtype:'textfield'
  259. },{
  260. allowBlank : true,
  261. width:500,
  262. fieldLabel:'Logo上传',
  263. name:'logoFilefield',
  264. xtype: 'filefield',
  265. emptyText: '请选择图片',
  266. buttonText: '',
  267. buttonConfig: {
  268. iconCls: 'x-fa fa-picture-o',
  269. },
  270. createFileInput : function() {
  271. var me = this;
  272. me.fileInputEl = me.button.el.createChild({
  273. name: me.getName(),
  274. cls: Ext.baseCSSPrefix + 'form-file-input',
  275. tag: 'input',
  276. type: 'file',
  277. size: 1,
  278. accept:"image/*"
  279. }).on('change', me.onFileChange, me);
  280. },
  281. listeners: {
  282. afterrender:function(field,ops){
  283. var fileEl = field.fileInputEl.dom;
  284. fileEl.setAttribute("accept","image/*");
  285. },
  286. change: function(field){
  287. var form = field.ownerCt.ownerCt;
  288. var myForm = field.ownerCt;
  289. var fileEl = field.fileInputEl.dom;
  290. var fd = new FormData();
  291. fd.append('file', fileEl.files[0]);
  292. form.setLoading(true);
  293. Ext.Ajax.request({
  294. url: 'http://192.168.253.31:8560/api/file/upload',//这里是填写需要跨域访问的URL
  295. cors: true,
  296. useDefaultXhrHeader: false,
  297. method: 'post',
  298. rawData: fd,
  299. headers: {
  300. 'Access-Control-Allow-Origin': '*',
  301. 'Authorization': saas.util.State.get('session').token,
  302. //"Content-Type": 'multipart/form-data' //文件上传的格式,
  303. "Content-Type":null
  304. },
  305. success: function (response, opts) {
  306. saas.util.BaseUtil.showToast('上传成功');
  307. var res = Ext.decode(response.responseText);
  308. if(res.success){
  309. var data = res.data;
  310. var name = data.name + " (" + Ext.util.Format.fileSize(data.size) + ")";
  311. myForm.down('[name=logoUrl]').setValue(data.fullPath);
  312. field.setRawValue(name);
  313. //读取图片
  314. if(data.id){
  315. var img = myForm.down('[name=LogoPhoto]');
  316. img.el.dom.src = 'http://192.168.253.31:8560/api/file/download?path='+data.fullPath;
  317. var showLogoPhoto = form.down('[name=showLogoPhoto]');
  318. showLogoPhoto.show();
  319. }
  320. }else{
  321. saas.util.BaseUtil.showToast('上传失败: ' + res.message);
  322. }
  323. form.setLoading(false);
  324. },
  325. failure: function (response, opts) {
  326. form.setLoading(false);
  327. var res = Ext.decode(response.responseText);
  328. saas.util.BaseUtil.showToast('上传失败: ' + res.message);
  329. }
  330. });
  331. }
  332. }
  333. },{
  334. xtype: 'image',
  335. style:'border:1px solid #f7f7f7;',
  336. width: 100,
  337. height: 100,
  338. margin:'5 0 5 150',
  339. src:'resources/images/default/basePhoto.png',
  340. name:'LogoPhoto',
  341. },{
  342. name:'showLogoPhoto',
  343. margin:'0 0 5 151',
  344. xtype:'container',
  345. cls:'x-container-group',
  346. hidden:true,
  347. items:[{
  348. width: 45,
  349. height: 24,
  350. xtype:'button',
  351. text:'查看',
  352. handler:function(b){
  353. var form = b.ownerCt.ownerCt.ownerCt;
  354. var img = form.down('[name=LogoPhoto]');
  355. form.lookPic(img);
  356. }
  357. },{
  358. margin:'0 0 0 10',
  359. width: 45,
  360. height: 24,
  361. xtype:'button',
  362. text:'下载',
  363. handler:function(b){
  364. var form = b.ownerCt.ownerCt.ownerCt;
  365. var path = form.down('[name=logoUrl]').value;
  366. form.downLoad(path);
  367. }
  368. }]
  369. }]
  370. }],
  371. initComponent: function () {
  372. var me = this,
  373. viewModel = me.getViewModel();
  374. var url = me._readUrl;
  375. saas.util.BaseUtil.request({url })
  376. .then(function(res) {
  377. if(res.success) {
  378. var d = res.data;
  379. viewModel.setData(d);
  380. viewModel.notify();
  381. me.load(me);
  382. }
  383. })
  384. .catch(function(response) {
  385. console.error(response);
  386. });
  387. me.callParent(arguments);
  388. },
  389. refresh:function(){
  390. this.ownerCt.setTitle('参数设置')
  391. },
  392. load:function(form){
  393. //打印章
  394. var signet = form.down('[name=signet]').value;
  395. if(signet&&signet!=''){
  396. var img = form.down('[name=SignetPhoto]');
  397. img.el.dom.src = 'http://192.168.253.31:8560/api/file/download?path='+signet;
  398. // var name = data.name + " (" + Ext.util.Format.fileSize(data.size) + ")";
  399. // myForm.down('[name=signet]').setValue(data.fullPath);
  400. // field.setRawValue(name);
  401. var showSignetPhoto = form.down('[name=showSignetPhoto]');
  402. showSignetPhoto.show();
  403. }
  404. //Logo
  405. var logoUrl = form.down('[name=logoUrl]').value;
  406. if(logoUrl&&logoUrl!=''){
  407. var img = form.down('[name=LogoPhoto]');
  408. img.el.dom.src = 'http://192.168.253.31:8560/api/file/download?path='+logoUrl;
  409. var showLogoPhoto = form.down('[name=showLogoPhoto]');
  410. showLogoPhoto.show();
  411. }
  412. //文件名称
  413. var viewModel = form.getViewModel();
  414. if(viewModel.data.fileInfoList&&viewModel.data.fileInfoList.length!=0){
  415. var logo = viewModel.data.fileInfoList[0].logo;
  416. var logoName = logo.name + " (" + Ext.util.Format.fileSize(logo.size) + ")";
  417. form.down('[name=logoFilefield]').setRawValue(logoName);
  418. var signet = viewModel.data.fileInfoList[0].signet;
  419. var signetName = signet.name + " (" + Ext.util.Format.fileSize(signet.size) + ")";
  420. form.down('[name=signetFilefield]').setRawValue(signetName);
  421. }
  422. },
  423. lookPic:function(img){
  424. var me = this, resizer = me.resizer,
  425. imageframe = document.getElementById('ext-image-frame');
  426. var src = img.el.dom.src;
  427. if (!imageframe) {
  428. var el = Ext.DomHelper.append(document.body, '<img id="ext-image-frame" src="' + src +
  429. '" width="500" height="400" style="position:absolute;left:0;top:0px;"/>', true);
  430. imageframe = el.dom;
  431. } else {
  432. imageframe.src = src;
  433. }
  434. if (!resizer) {
  435. resizer = this.resizer = Ext.create('Ext.resizer.Resizer', {
  436. target: 'ext-image-frame',
  437. pinned: true,
  438. width: 410,
  439. height: 310,
  440. minWidth: 100,
  441. minHeight: 80,
  442. preserveRatio: true,
  443. handles: 'all',
  444. dynamic: true,
  445. constrainTo:me.getEl()
  446. });
  447. var resizerEl = resizer.getEl();
  448. resizerEl.on('dblclick', function(){
  449. resizerEl.hide(true);
  450. });
  451. }
  452. resizer.getEl().center();
  453. resizer.getEl().show(true);
  454. Ext.DomHelper.applyStyles(imageframe, 'position:absolute;z-index:100;');
  455. },
  456. downLoad:function(path){
  457. //ajax 响应下载必须要创建一个form实例
  458. window.location.href = 'http://192.168.253.31:8560/api/file/download?path='+path;
  459. // if (!Ext.fly('ext-attach-download')) {
  460. // var frm = document.createElement('form');
  461. // frm.id = 'ext-attach-download';
  462. // frm.name = id;
  463. // frm.className = 'x-hidden';
  464. // document.body.appendChild(frm);
  465. // }
  466. // Ext.Ajax.request({
  467. // url: 'http://192.168.253.31:8560/api/file/download?path='+path,
  468. // method: 'post',
  469. // form: Ext.fly('ext-attach-download'),
  470. // isUpload: true,
  471. // params: ''
  472. // });
  473. }
  474. });