К основному контенту

Tooltip Dialog. Базовые компоненты Extension Library

Сегодня рассмотрим последний компонент, из обозначенных мной как основных - это Tooltil Dialog

1. Application Layout
6. Tooltip Dialog
--- Дополнительно ---
8. Bread Crumbs


Tooltip Dialog
Назвал бы его всплывающий, а лучше контекстный диалог. По своей сути этот тот же Dialog, но в несколько облегченном (в плане дизайна) варианте. Не зря обозвал его контекстным, поскольку еще одна особенность этого типа диалога: привязка отображения к объекту. При описании вызова Tooltip Dialog станет понятнее. а пока вид компонента после его добавления из палитры.

Пожалуй основное свойство этого компонента - это id, по которому вы будете к нему обращаться.

Для вызова корректного отображения используется вызов с клиентской стороны
XSP.openTooltipDialog ("#{id:ID_диалога}", "#{id:ID_компонента_привязки}")
Вызов вида getComponent('ID_диалога').show() тоже отобразит диалог, но без привязки к компоненту. Специального метода show("ID") нет.

Закрыть диалог по действию можно точно так же как и компонент Dialog:
с клиентской стороны: XSP.closeTooltipDialog('#{id:ID_диалога}') или XSP.closeTooltipDialog('#{id:ID_диалога}','#{id:ID_обновляемого_компонента}')
с серверной стороны: getComponent("ID_диалога").hide() или getComponent("ID_диалога").hide("ID_обновляемого_компонента"),
где ID_обновляемого_компонента - компонент, который обновляется после закрытия диалога

Итог выглядит весьма симпатично

Пример можно пощупать как всегда в Демо-приложении

Комментарии

Популярные сообщения из этого блога

Занимательные алгоритмы. Поиск цикла в односвязном списке

И снова про тараканов, которые иногда возникают в голове. Как-то раз, засыпая, я задумался на курьезными задачками из своей сферы деятельности (Lotus Notes), которые можно было бы задать на собеседовании, плавно перешел к воспоминаниям о своих первых собеседования, когда опыта работы еще не было. Опыт самих собеседований у меня не велик а места, где задавались действительно интересные задачи (а не задачки типа: написать сортировку массива любым известным способом) вообще равны одному - это ABBYY. Как минимум одна задачка в списке на знание и понимание классических алгоритмов, описанных в книге Дональда Кнута -  Искусство программирования .

Unit-testing object validation when validator has DI

Summary Unit test object validation when validator(s) has a dependency. For instance, we have some custom field and cross-field validators. Want to test their combination. Additionally some of validators have dependencies, injected through constructor or setters. You're not using property injection, right? Shortcut If you are just searching for an answer, here's the fast way: Declare CustomConstraintValidatorFactory that implements javax.validation.ConstraintValidatorFactory Override getInstance method and on facing your constraint validator class instantiate it Otherwise delegate validator construction to org.hibernate.validator.internal.engine.constraintvalidation.ConstraintValidatorFactoryImpl Build validator factory and provide it your CustomConstraintValidatorFactory Build validator, using that factory... Go to demo project on GitHub for details:  https://github.com/MrArtemAA/blog-demos/blob/master/test-validator-with-injection/src/test/java/ru/artemaa/...

Use @SpringBootTest for validator's unit test and be fast enough

This a continuation of the post: https://live-scripts.blogspot.com/2020/02/unit-testing-object-validation-with-di-in-validator.html#more . Last time we talked about testing a validator, which has a dependency. Using pure @SpringBootTest turned out to be too slow. So I showed a "trick" to override the validator's factory in order to inject the dependant object. This reduced test run time. I promised to show a way to use @SpringBootTest , autowiring, and still be quick enough.