SpecialContainField.js 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. /**
  2. *
  3. */
  4. Ext.define('erp.view.core.form.SpecialContainField', {
  5. extend: 'Ext.form.FieldContainer',
  6. alias: 'widget.specialcontianfield',
  7. height: 27,
  8. items: [],
  9. layout:'column',
  10. columnWidth:1,
  11. showscope: true,
  12. initComponent : function(){
  13. this.callParent(arguments);
  14. var me = this;
  15. var logic=this.logic;
  16. var value=this.value;
  17. var arr=logic.split(";");
  18. var valuearr=value.split(";");
  19. Ext.Array.each(arr,function(item,index){
  20. if(logic.indexOf(";")>0){
  21. me.insert(0,{
  22. xtype:'hidden',
  23. name:me.name,
  24. id:me.name+"_checks",
  25. value:me.value
  26. //margin:'50 0 0 0'
  27. });
  28. if(item.indexOf('checkbox')==0 && item.indexOf("#")>0){
  29. me.insert(index+1,{
  30. xtype:'checkbox',
  31. columnWidth:0.4,
  32. boxLabel:item.split("#")[1],
  33. labelSeparator:'',
  34. boxLabelAlign:'before',
  35. labelWidth:0,
  36. margin:'0 0 0 120',
  37. checked:valuearr[index]==1,
  38. listeners:{
  39. change:function(field,newValue,oldValue){
  40. if(newValue){
  41. me.setFiledValue();
  42. }else {
  43. me.setFiledValue();
  44. }
  45. }
  46. }
  47. });
  48. }else if(item=='combo'){
  49. me.insert(index+1,{
  50. xtype:'combo',
  51. hideLabel:true
  52. });
  53. }else if(item=='text'){
  54. me.insert(index+1,{
  55. xtype:'textfield',
  56. hideLabel:true,
  57. columnWidth:0.6,
  58. labelWidth:0,
  59. value:valuearr[index],
  60. margin:'0 0 0 -55',
  61. fieldStyle:'background:#FFFAFA;color:#515151;',
  62. listeners:{
  63. change:function(field,newValue,oldValue){
  64. if(newValue){
  65. me.setFiledValue();
  66. }else {
  67. me.setFiledValue();
  68. }
  69. }
  70. }
  71. });
  72. }else{
  73. me.insert(index+1,{
  74. xtype: 'displayfield',
  75. fieldStyle:'color:black;font-size:15px;margin-left:150px',
  76. value: item
  77. });
  78. }
  79. }else {
  80. me.insert(0,{
  81. xtype:'textfield',
  82. labelWidth:400,
  83. columnWidth:0.9,
  84. name:me.name,
  85. value:me.value,
  86. id:me.name+'_checks',
  87. fieldStyle:'background:#FFFAFA;color:#515151;',
  88. fieldLabel:item.split('#')[1]
  89. });
  90. }
  91. });
  92. },
  93. setFiledValue:function(){
  94. var value="";
  95. var items=this.items.items;
  96. for(var i=1;i<items.length;i++){
  97. if(items[i].xtype=='checkbox'){
  98. if(items[i].value){
  99. value+="1;";
  100. }else {
  101. value+="-1;";
  102. }
  103. }else {
  104. if(items[i].value){
  105. value +=items[i].value+";";
  106. }else value +=";";
  107. }
  108. }
  109. value=value.substring(0,value.length-1);
  110. this.items.items[0].setValue(value);
  111. },
  112. isValid: function(){
  113. return this.items.items[0].isValid();
  114. },
  115. setValue: function(value){
  116. this.value=value;
  117. },
  118. isDirty:function(){
  119. return true;
  120. },
  121. listeners: {
  122. afterrender: function(){
  123. this.getEl().dom.childNodes[1].style.height = 22;
  124. this.getEl().dom.childNodes[1].style.overflow = 'hidden';
  125. }
  126. }
  127. });