123456789101112131415161718192021222324252627282930313233343536373839 |
- Popup.template.events({
- 'click .js-back-view'() {
- Popup.back();
- },
- 'click .js-close-pop-over'() {
- Popup.close();
- },
- 'click .js-confirm'() {
- this.__afterConfirmAction.call(this);
- },
- // This handler intends to solve a pretty tricky bug with our popup
- // transition. The transition is implemented using a large container
- // (.content-container) that is moved on the x-axis (from 0 to n*PopupSize)
- // inside a wrapper (.container-wrapper) with a hidden overflow. The problem
- // is that sometimes the wrapper is scrolled -- even if there are no
- // scrollbars. This happen for instance when the newly opened popup has some
- // focused field, the browser will automatically scroll the wrapper, resulting
- // in moving the whole popup container outside of the popup wrapper. To
- // disable this behavior we have to manually reset the scrollLeft position
- // whenever it is modified.
- 'scroll .content-wrapper'(evt) {
- evt.currentTarget.scrollLeft = 0;
- },
- });
- // When a popup content is removed (ie, when the user press the "back" button),
- // we need to wait for the container translation to end before removing the
- // actual DOM element. For that purpose we use the undocumented `_uihooks` API.
- Popup.template.onRendered(() => {
- const container = this.find('.content-container');
- container._uihooks = {
- removeElement(node) {
- $(node).addClass('no-height');
- $(container).one(CSSEvents.transitionend, () => {
- node.parentNode.removeChild(node);
- });
- },
- };
- });
|