| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- /**
- * From-To dbfindtrigger
- * @author yingp
- */
- Ext.define('erp.view.core.form.FtFindField', {
- extend: 'Ext.form.FieldContainer',
- alias: 'widget.ftfindfield',
- layout: 'column',
- value: "BETWEEN '' AND ''",
- valuePrint:"",
- baseCls: null,
- autoScroll: false,
- height: 22,
- items: [],
- initComponent : function(){
- this.callParent(arguments);
- var me = this;
- me.insert(0, {
- xtype: 'dbfindtrigger',
- id: me.name + '_from',
- name: me.name,
- columnWidth: 0.5,
- fieldStyle: me.fieldStyle,
- listeners: {
- change: function(f){
- var from = f.value;
- var to = me.items.items[1].value;
- from = from == null || from == '' ? to == null || to == '' ? '' : to : from;
- to = to == null || to == '' ? from == null || from == '' ? '' : from : to;
- if(from == ''){
- me.value = '';
- me.valuePrint = '';
- } else {
- me.value = "BETWEEN '" + from + "' AND '" + to + "'";
- if(me.ownerCt){
- var tablename = me.ownerCt.tablename;
- me.valuePrint="{"+tablename+"."+me.name+"}>='"+from+"' and {"+tablename+"."+me.name+"}<='"+to+"'";
- }
- }
- }
- }
- });
- me.insert(1, {
- xtype: 'dbfindtrigger',
- id: me.name + '_to',
- name: me.name,
- columnWidth: 0.5,
- fieldStyle: me.fieldStyle,
- listeners: {
- change: function(f){
- var from = me.items.items[0].value;
- var to = f.value;
- from = from == null || from == '' ? to == null || to == '' ? '' : to : from;
- to = to == null || to == '' ? from == null || from == '' ? '' : from : to;
- if(from == ''){
- me.value = '';
- me.valuePrint = '';
- } else {
- me.value = "BETWEEN '" + from + "' AND '" + to + "'";
- if(me.ownerCt){
- var tablename = me.ownerCt.tablename;
- me.valuePrint="{"+tablename+"."+me.name+"}>='"+from+"' and {"+tablename+"."+me.name+"}<='"+to+"'";
- }
- }
- }
- }
- });
- },
- setValue: function(v){
- var f = Ext.getCmp(window.onTriggerClick);
- if(f){
- f.setValue(v);
- }
- if(v != null && v != '' && contains(v, '~', true)){
- this.items.items[0].setValue(v.split('~')[0]);
- this.items.items[1].setValue(v.split('~')[1]);
- }
- },
- listeners: {
- afterrender: function(){
- var tb = this.getEl().dom;
- if(tb.nodeName == 'TABLE') {
- return;
- }
- tb.childNodes[1].style.height = 22;
- tb.childNodes[1].style.overflow = 'hidden';
- }
- },
- reset: function(){
- this.items.items[0].reset();
- this.items.items[1].reset();
- },
- getValue: function(){
- if(this.items.items[0].value != null && this.items.items[0].value != ''){
- if(this.items.items[0].value == null || this.items.items[0].value == ''){
- return this.items.items[1].value + '~' + this.items.items[1].value;
- } else if(this.items.items[1].value == null || this.items.items[1].value == ''){
- return this.items.items[0].value + '~' + this.items.items[0].value;
- } else {
- return this.items.items[0].value + '~' + this.items.items[1].value;
- }
- } else {
- return '';
- }
- },
- isValid: function(){
- return true;
- }
- });
|