FtDateField.js 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /**
  2. * From-To datefield
  3. * @author yingp
  4. */
  5. Ext.define('erp.view.core.form.FtDateField', {
  6. extend: 'Ext.form.FieldContainer',
  7. alias: 'widget.ftdatefield',
  8. layout: 'column',
  9. value: "BETWEEN '' AND ''",
  10. height: 22,
  11. items: [],
  12. initComponent : function(){
  13. this.callParent(arguments);
  14. var me = this, allowBlank = (Ext.isDefined(me.allowBlank) ? me.allowBlank : true);
  15. Ext.apply(me.fieldDefaults, {
  16. allowBlank: allowBlank
  17. });
  18. me.insert(0, {
  19. xtype: 'datefield',
  20. columnWidth: 0.5,
  21. fieldStyle: me.fieldStyle,
  22. listeners: {
  23. change: function(){
  24. var from = me.items.items[0].value;
  25. var to = me.items.items[1].value;
  26. me.items.items[1].setMinValue(from);
  27. from = from == null || from == '' ? to == null || to == '' ? '' : to : from;
  28. to = to == null || to == '' ? from == null || from == '' ? '' : from : to;
  29. me.value = "BETWEEN to_date('" + Ext.Date.format(from,'Y-m-d') + " 00:00:00','yyyy-mm-dd hh24:mi:ss') AND to_date('"
  30. + Ext.Date.format(to,'Y-m-d') + " 23:59:59','yyyy-mm-dd hh24:mi:ss')";
  31. me.firstItem.value = from;
  32. me.secondItem.value = to;
  33. }
  34. }
  35. });
  36. me.insert(1, {
  37. xtype: 'datefield',
  38. columnWidth: 0.5,
  39. fieldStyle: me.fieldStyle,
  40. listeners: {
  41. change: function(){
  42. var from = me.items.items[0].value;
  43. var to = me.items.items[1].value;
  44. me.items.items[0].setMaxValue(to);
  45. from = from == null || from == '' ? to == null || to == '' ? '' : to : from;
  46. to = to == null || to == '' ? from == null || from == '' ? '' : from : to;
  47. me.value = "BETWEEN to_date('" + Ext.Date.format(from,'Y-m-d') + " 00:00:00','yyyy-mm-dd hh24:mi:ss') AND to_date('"
  48. + Ext.Date.format(to,'Y-m-d') + " 23:59:59','yyyy-mm-dd hh24:mi:ss')";
  49. me.firstItem.value = from;
  50. me.secondItem.value = to;
  51. }
  52. }
  53. });
  54. this.firstItem = this.items.items[0];
  55. this.secondItem = this.items.items[1];
  56. },
  57. reset: function(){
  58. this.items.items[0].reset();
  59. this.items.items[1].reset();
  60. },
  61. setValue: function(value){
  62. if(value != null && value != '' && contains(value, '~', true)){
  63. this.items.items[0].setValue(value.split('~')[0]);
  64. this.items.items[1].setValue(value.split('~')[1]);
  65. }
  66. },
  67. setValues: function(first, second) {
  68. this.firstItem.setValue(first);
  69. this.secondItem.setValue(second || first || null);
  70. },
  71. listeners: {
  72. afterrender: function(){
  73. var tb = this.getEl().dom;
  74. if(tb.nodeName == 'TABLE') {
  75. return;
  76. }
  77. tb.childNodes[1].style.height = 22;
  78. tb.childNodes[1].style.overflow = 'hidden';
  79. }
  80. },
  81. getValue: function(){
  82. if(this.items.items[0].value != null && this.items.items[0].value != ''){
  83. return Ext.Date.format(this.items.items[0].value, 'Y-m-d') + '~' + Ext.Date.format(this.items.items[1].value, 'Y-m-d');
  84. } else {
  85. return '';
  86. }
  87. },
  88. isValid: function(){
  89. return true;
  90. },
  91. getFilter: function() {
  92. var me = this, fromVal = me.firstItem.getValue(), toVal = me.secondItem.getValue();
  93. return (fromVal || toVal) ? {
  94. "gte": fromVal ? Ext.Date.format(fromVal, 'Y-m-d') : null,
  95. "lte": toVal ? Ext.Date.format(toVal, 'Y-m-d') : null
  96. } : null;
  97. }
  98. });