Jump to content

Выпадающее мобильное меню для unimToolbar


x11

Recommended Posts

Подскажите, пожалуйста, как с помощью чего можно реализовать выпадающее меню?

И привязать его к кнопке или к контейнеру на TunimToolbar.

Может быть вместо меню можно использовать какую-нибудь другую компоненту?

Спасибо.

Screenshot_5.jpg

Link to comment
Share on other sites

On 1/25/2021 at 2:34 PM, x11 said:

Подскажите, пожалуйста, как с помощью чего можно реализовать выпадающее меню?

И привязать его к кнопке или к контейнеру на TunimToolbar.

Может быть вместо меню можно использовать какую-нибудь другую компоненту?

UnimButton -> ClientEvents -> UniEvents ->

function beforeInit(sender, config)
{
    config.arrowAlign = 'bottom';
    config.menu = [
        { text: 'Item 1' },
        { text: 'Item 2' },
        { text: 'Item 3' },
        { text: 'Item 4' }
    ];
}

 

  • Like 1
Link to comment
Share on other sites

1 hour ago, Sherzod said:

iconCls: 'x-fa fa-home',

еще хотел бы уточнить по поводу иконок: как правильно формировать (составлять) название?

вот пример https://fontawesome.com/icons/eraser?style=solid

так правильно 'fas fa-eraser'?

Или так 'x-fa fa-eraser'?

Или еще как-то по-другому?

Откуда взялось это "x-fa"?

 

Screenshot_9.jpg

Screenshot_10.jpg

Link to comment
Share on other sites

А еще вопрос. А можно у какого-нибудь пункта меню задействовать checkbox, если такое возможно?

И как работать с меню типа checked?

Спасибо.

Link to comment
Share on other sites

23 minutes ago, x11 said:

А еще вопрос. А можно у какого-нибудь пункта меню задействовать checkbox, если такое возможно?

И как работать с меню типа checked?

function beforeInit(sender, config)
{
    config.arrowAlign = 'bottom';
    config.menu = [
        { text: 'Item 1', xtype: 'menucheckitem', iconCls: 'x-fa fa-home', checkHandler: function() {alert(this.getChecked())} },  //hideOnClick: false/true
        { text: 'Item 2' },
        { text: 'Item 3' },
        { text: 'Item 4' }
    ]
}

 

  • Like 1
Link to comment
Share on other sites

8 hours ago, Sherzod said:

xtype: 'menucheckitem'

 

Вы случайно не знаете, почему отображается непонятное состояние? Т.е. среднее: не включено и не отключено.

Вторая картинка - это другие возможные состояния рисует это меню.

 

Screenshot_8.jpg

Screenshot_9.jpg

Link to comment
Share on other sites

7 minutes ago, x11 said:

Просто одно и то же состояние отображается по разному: серый или белый квадратик, что вводит в заблуждение.

Это при наведении курсора мыши?

Link to comment
Share on other sites

нет, при раскрытии - серое, а потом, когда начинаешь нажимать на меню уже не серое, а белое.

но на смартфоне я еще не тестировал, проблема проявляется в десктопном Хроме

Link to comment
Share on other sites

Проверил на смартфоне (Chrome и Firefox): первое открытие - серый квадратик, а когда нажимаешь, то уже потом он белым становится.

Link to comment
Share on other sites

Ну да, как бы в этом и проблема, т.е. при открытии чекбокс серый изначально, а по идее должен быть вот такой.

 

 

Screenshot_1.jpg

Link to comment
Share on other sites

Наверное, до меня дошло.

Белый становится он потому, что весь пункт меню выделяется голубым цветом.

Т.е. невыбранный пункт меню - серый. А выбранный - белый.

  • Upvote 1
Link to comment
Share on other sites

А можно ли это меню привязать к XTamplate?

Если да, то подскажите, пожалуйста, как?

с помощью этих двух процедур у меня отображается таблица TUnimDBListGrid + XTamplate:

function beforeInit(sender, config){
	config.loadMask = false;
	config.loadingText = 'загрузка...';
	config.emptyText = 'даних немає'; 
	config.grouped = false;
  	var descr = '<table class="tblResDescr">' +
                    '<tr>' +
						'<td class="tdDbgRowID">ID {[this.getVal(values, "ID")]}</td>' +
							'<td class="tdBtnPopup"><button class="btnPopup" data-id="{[this.getVal(values, "ID")]}" type-id="{[this.getVal(values, "ID")]}"><i class="fas fa-angle-down"></i></td>' +
						'</tr>' +                     
                    '<tr>' +
                        '<td colspan="2">Ціна {[this.getVal(values, "PRICE")]}</td>' +
                    '</tr>' +                   
                    ...
    				...
    				...
                    '</tr>'+
                '</table>';
	config.itemTpl = new Ext.XTemplate('<table class="tblRes">' +
                     '<tr>' +
						...
                        ...

 

function afterCreate(sender) {
   Ext.getCmp(sender.id).bodyElement.addListener('click', function(event, target) {
        if (target.getAttribute('class').includes('btnPopup')) {
            ajaxRequest(sender, "eventPopup", ['objId=' + target.getAttribute('data-id'),
						'typeId=' + target.getAttribute('type-id')]);
        }
    }, null, {
        delegate: 'table button'
    });
}

спасибо

Т.е. нужно знать для какого data-id всплывает меню

Screenshot_2.jpg

Link to comment
Share on other sites

On 2/1/2021 at 10:14 PM, x11 said:

А можно ли это меню привязать к XTamplate?

Если да, то подскажите, пожалуйста, как?

с помощью этих двух процедур у меня отображается таблица TUnimDBListGrid + XTamplate:

Надо проанализировать. Если есть тестовый случай, прикрепите пожалуйста.

Link to comment
Share on other sites

23 hours ago, Sherzod said:

Если есть тестовый случай, прикрепите пожалуйста.

вот, на какую-нибудь кнопку повесить бы выпадающее меню

в папке "\Win32\Debug\files" находятся дополнительные файлы для меню и для XTamplate.

Screenshot_1.jpg

uniGUI_menu.zip

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...