Поле месяца в EXTJS 5.1

Я получил эту потрясающую скрипку https://fiddle.sencha.com/#fiddle/h5i от еще один пост о переполнении стека (спасибо, Игорь). НО у меня есть одна проблема: код не работает, если я выбираю версию extjs 5.1, которую я использую в своем приложении. Проблема в том, что когда я нажимаю на месяц или год, календарь просто закрывается (вы можете попробовать это поведение, установив версию 5.1 и снова запустив скрипт). Я пытался настраивать части кода, но ничего не изменилось :s.

У кого-нибудь есть идеи, почему это не работает с extjs 5.1 или как я могу решить эту проблему?

Заранее спасибо :) !


person JkSuf    schedule 28.01.2015    source источник
comment
У меня отлично работает в ExtJs 5.1, используя FireFox   -  person Scriptable    schedule 28.01.2015
comment
ОЙ !! Да, это работает и в IE !! Но на хроме не работает!! Так странно ^^'   -  person JkSuf    schedule 29.01.2015


Ответы (3)


Почему-то поведение Chrome отличается. Попробуйте следующее:

createPicker: function () {
    var me = this,
        format = Ext.String.format,
        pickerConfig;

    pickerConfig = {
        pickerField: me,
        ownerCmp: me,
        renderTo: document.body,
        floating: true,
        hidden: true,
        focusOnShow: true,
        minDate: me.minValue,
        maxDate: me.maxValue,
        disabledDatesRE: me.disabledDatesRE,
        disabledDatesText: me.disabledDatesText,
        disabledDays: me.disabledDays,
        disabledDaysText: me.disabledDaysText,
        format: me.format,
        showToday: me.showToday,
        startDay: me.startDay,
        minText: format(me.minText, me.formatDate(me.minValue)),
        maxText: format(me.maxText, me.formatDate(me.maxValue)),
        listeners: {
            select: { scope: me, fn: me.onSelect },
            monthdblclick: { scope: me, fn: me.onOKClick },
            yeardblclick: { scope: me, fn: me.onOKClick },
            OkClick: { scope: me, fn: me.onOKClick },
            CancelClick: { scope: me, fn: me.onCancelClick }
        },
        keyNavConfig: {
            esc: function () {
                me.collapse();
            }
        }
    };

    if (Ext.isChrome) {
        me.originalCollapse = me.collapse;
        pickerConfig.listeners.boxready = {
            fn: function () {
                this.picker.el.on({
                    mousedown: function () {
                        this.collapse = Ext.emptyFn;
                    },
                    mouseup: function () {
                        this.collapse = this.originalCollapse;
                    },
                    scope: this
                });
            },
            scope: me,
            single: true
        }
    }

    return Ext.create('Ext.picker.Month', pickerConfig);
}
person Baidaly    schedule 05.03.2015
comment
Есть ли способ предотвратить ручной ввод в это пользовательское поле даты. то есть я должен иметь возможность давать значение только через сборщик - person Priya; 06.09.2019

Добавьте свойства:

onFocusLeave: Ext.emptyFn

person ajokn    schedule 14.04.2015

Попробуйте это, у меня отлично работает.

Ext.onReady(function() {
  Ext.define('Ext.form.field.Month', {
    extend: 'Ext.form.field.Date',
    alias: 'widget.monthfield',
    requires: ['Ext.picker.Month'],
    alternateClassName: ['Ext.form.MonthField', 'Ext.form.Month'],
    selectMonth: null,
    createPicker: function() {
      var me = this,
        format = Ext.String.format;
      return Ext.create('Ext.picker.Month', {
        pickerField: me,
        ownerCt: me.ownerCt,
        renderTo: document.body,
        floating: true,
        hidden: true,
        focusOnShow: true,
        minDate: me.minValue,
        maxDate: me.maxValue,
        disabledDatesRE: me.disabledDatesRE,
        disabledDatesText: me.disabledDatesText,
        disabledDays: me.disabledDays,
        disabledDaysText: me.disabledDaysText,
        format: me.format,
        showToday: me.showToday,
        startDay: me.startDay,
        minText: format(me.minText, me.formatDate(me.minValue)),
        maxText: format(me.maxText, me.formatDate(me.maxValue)),
        listeners: {
          select: {
            scope: me,
            fn: me.onSelect
          },
          monthdblclick: {
            scope: me,
            fn: me.onOKClick
          },
          yeardblclick: {
            scope: me,
            fn: me.onOKClick
          },
          OkClick: {
            scope: me,
            fn: me.onOKClick
          },
          CancelClick: {
            scope: me,
            fn: me.onCancelClick
          }
        },
        keyNavConfig: {
          esc: function() {
            me.collapse();
          }
        }
      });
    },
    onCancelClick: function() {
      var me = this;
      me.selectMonth = null;
      me.collapse();
    },
    onOKClick: function() {
      var me = this;
      if (me.selectMonth) {
        me.setValue(me.selectMonth);
        me.fireEvent('select', me, me.selectMonth);
      }
      me.collapse();
    },
    onSelect: function(m, d) {
      var me = this;
      me.selectMonth = new Date((d[0] + 1) + '/1/' + d[1]);
    }
  });

  Ext.create('Ext.form.field.Month', {
    format: 'F, Y',
    fieldLabel: 'Date',
    renderTo: Ext.getBody()
  });
});
person M.A.K. Ripon    schedule 15.09.2018