diff --git a/dist/OutSystemsUI.css b/dist/OutSystemsUI.css index 7449f8dbb1..a3ca737249 100644 --- a/dist/OutSystemsUI.css +++ b/dist/OutSystemsUI.css @@ -79,33 +79,35 @@ Section Index: 6.3.1. Action Sheet 6.3.2. Animate 6.3.3. Animated Label - 6.3.4. Bottom Sheet - 6.3.5. Carousel - 6.3.6. DatePicker - 6.3.7. Dropdown - 6.3.7.1 Dropdown Search - 6.3.7.2 Dropdown Tags - 6.3.8. Floating Actions - 6.3.9. Input With Icon - 6.3.10. Lightbox Image - 6.3.11. MonthPicker - 6.3.12. Notification - 6.3.13. RangeSlider - 6.3.14. Scrollable Area - 6.3.15. Search - 6.3.16. Sidebar - 6.3.17. Stacked Cards - 6.3.18. TimePicker - 6.3.19. Video + 6.3.4. Balloon + 6.3.5. Bottom Sheet + 6.3.6. Carousel + 6.3.7. DatePicker + 6.3.8. Dropdown + 6.3.8.1 Dropdown Search + 6.3.8.2 Dropdown Tags + 6.3.9. Floating Actions + 6.3.10. Input With Icon + 6.3.11. Lightbox Image + 6.3.12. MonthPicker + 6.3.13. Notification + 6.3.14. RangeSlider + 6.3.15. Scrollable Area + 6.3.16. Search + 6.3.17. Sidebar + 6.3.18. Stacked Cards + 6.3.19. TimePicker + 6.3.20. Video 6.4. Navigation 6.4.1. Bottom Bar Item 6.4.2. Breadcrumbs - 6.4.3. Pagination - 6.4.4. Section Index - 6.4.5. Submenu - 6.4.6. Tabs - 6.4.7. Timeline - 6.4.8. Wizard + 6.4.3. OverflowMenu + 6.4.4. Pagination + 6.4.5. Section Index + 6.4.6. Submenu + 6.4.7. Tabs + 6.4.8. Timeline + 6.4.9. Wizard 6.5. Numbers 6.5.1. Badge 6.5.2. Counter @@ -792,8 +794,7 @@ body, } .phone .layout .main-content .layout.layout-native{ -servicestudio-min-width:100vw; -} -/*! 3.2. Header */ +} /*! 3.2. Header */ .header{ background-color:var(--header-color); -webkit-box-shadow:0 1px 5px 0 rgba(21, 24, 26, 0.1); @@ -7720,7 +7721,106 @@ span.flatpickr-weekday{ -webkit-box-shadow:0 3px 0 0 var(--color-focus-outer); box-shadow:0 3px 0 0 var(--color-focus-outer); } -/*! 6.3.4. Bottom Sheet */ +/*! 6.3.4. Balloon */ +.osui-balloon{ + --border-radius-rounded:16px; + --osui-floating-position-x:0; + --osui-floating-position-y:0; + -webkit-box-shadow:var(--shadow-s); + box-shadow:var(--shadow-s); + border-radius:var(--osui-balloon-shape); + background-color:var(--color-neutral-0); + height:auto; + left:var(--osui-floating-position-x); + opacity:0; + position:absolute; + pointer-events:none; + top:var(--osui-floating-position-y); + visibility:hidden; + width:-webkit-max-content; + width:-moz-max-content; + width:max-content; + z-index:var(--layer-global-elevated); +} +.osui-balloon--is-open{ + visibility:visible; + opacity:1; + pointer-events:all; + -webkit-transition:opacity 300ms ease-in; + -o-transition:opacity 300ms ease-in; + transition:opacity 300ms ease-in; +} +.osui-balloon:not(.osui-balloon--is-open) *{ + display:none; +} +.osui-balloon{ + -servicestudio-left:0; + -servicestudio-min-width:170px; + -servicestudio-opacity:1; + -servicestudio-position:absolute; + -servicestudio-top:100%; + -servicestudio-visibility:visible; +} +.osui-balloon.bottom{ + -servicestudio-left:50%; + -servicestudio-transform:translate(-50%); +} +.osui-balloon.bottom-start{ + -servicestudio-left:0; +} +.osui-balloon.bottom-end{ + -servicestudio-left:100%; + -servicestudio-transform:translateX(-100%); +} +.osui-balloon.center{ + -servicestudio-top:0; + -servicestudio-left:0; +} +.osui-balloon.left-end{ + -servicestudio-top:100%; + -servicestudio-transform:translateY(-100%) translateX(-100%); +} +.osui-balloon.left-start{ + -servicestudio-top:0; + -servicestudio-transform:translateX(-100%); +} +.osui-balloon.left{ + -servicestudio-top:50%; + -servicestudio-transform:translateY(-50%) translateX(-100%); +} +.osui-balloon.right-end{ + -servicestudio-top:100%; + -servicestudio-left:100%; + -servicestudio-transform:translateY(-100%); +} +.osui-balloon.right-start{ + -servicestudio-top:0; + -servicestudio-left:100%; +} +.osui-balloon.right{ + -servicestudio-top:50%; + -servicestudio-left:100%; + -servicestudio-transform:translateY(-50%); +} +.osui-balloon.top-end{ + -servicestudio-top:0; + -servicestudio-left:100%; + -servicestudio-transform:translateY(-100%) translateX(-100%); +} +.osui-balloon.top-start{ + -servicestudio-top:0; + -servicestudio-left:0; + -servicestudio-transform:translateY(-100%); +} +.osui-balloon.top{ + -servicestudio-top:0; + -servicestudio-left:50%; + -servicestudio-transform:translateY(-100%) translateX(-50%); +} +.osui-tabs__header-item .osui-balloon{ + position:fixed; +} +/*! 6.3.5. Bottom Sheet */ .osui-bottom-sheet{ --bottom-sheet-max-height:calc(100vh - 54px); --border-radius-sharp:none; @@ -7892,7 +7992,7 @@ span.flatpickr-weekday{ .osui-bottom-sheet--is-active .osui-bottom-sheet__content .osui-timepicker{ position:relative; } -/*! 6.3.5. Carousel */ +/*! 6.3.6. Carousel */ .osui-carousel{ --osui-carousel-track-width:100%; --osui-carousel-pagination-margin:30px; @@ -8011,7 +8111,7 @@ span.flatpickr-weekday{ .splide__track--fade > .splide__list > .splide__slide.is-active{ z-index:var(--layer-local-tier-1); } -/*! 6.3.6. DatePicker */ +/*! 6.3.7. DatePicker */ .flatpickr-calendar{ --osui-flatpickr-layer:var(--layer-global-elevated); border-radius:var(--border-radius-soft); @@ -8519,7 +8619,7 @@ html[data-uieditorversion^="1"] .osui-datepicker-calendar-ss-preview.has-today-b -servicestudio-padding-top:min(390px, 100%); -servicestudio-height:0; } -/*! 6.3.7. Dropdown */ +/*! 6.3.8. Dropdown */ .vscomp-ele{ max-width:initial; } @@ -8991,7 +9091,7 @@ body.vscomp-popup-active .vscomp-wrapper{ margin-left:var(--space-s); margin-right:initial; } -/*! 6.3.7.1 Dropdown Search */ +/*! 6.3.8.1 Dropdown Search */ .osui-dropdown-search.osui-dropdown--not-valid .vscomp-toggle-button{ border-color:var(--color-error); } @@ -9016,7 +9116,7 @@ body.vscomp-popup-active .vscomp-wrapper{ -servicestudio-right:16px; -servicestudio-top:8px; } -/*! 6.3.7.2 Dropdown Tags */ +/*! 6.3.8.2 Dropdown Tags */ .osui-dropdown-tags.osui-dropdown--not-valid .vscomp-toggle-button{ border-color:var(--color-error); } @@ -9082,7 +9182,7 @@ body.vscomp-popup-active .vscomp-wrapper{ -servicestudio-top:50%; -servicestudio-transform:translate(-50%, -50%); } -/*! 6.3.8. Floating Actions */ +/*! 6.3.9. Floating Actions */ .floating{ --osui-floating-actions-layer:var(--layer-global-elevated); } @@ -9301,7 +9401,7 @@ body.vscomp-popup-active .vscomp-wrapper{ -webkit-box-shadow:0 0 0 3px var(--color-focus-outer); box-shadow:0 0 0 3px var(--color-focus-outer); } -/*! 6.3.9. Input With Icon */ +/*! 6.3.10. Input With Icon */ .input-with-icon{ display:-webkit-box; display:-ms-flexbox; @@ -9359,7 +9459,7 @@ body.vscomp-popup-active .vscomp-wrapper{ padding-bottom:var(--space-m); z-index:var(--layer-local-tier-1); } -/*! 6.3.10. Lightbox Image */ +/*! 6.3.11. Lightbox Image */ .lightbox-item{ -servicestudio-position:relative; } @@ -9441,7 +9541,7 @@ body.vscomp-popup-active .vscomp-wrapper{ -ms-flex-direction:row-reverse; flex-direction:row-reverse; } -/*! 6.3.11. MonthPicker */ +/*! 6.3.12. MonthPicker */ .osui-monthpicker__dropdown.flatpickr-calendar{ width:auto; } @@ -9539,7 +9639,7 @@ body.vscomp-popup-active .vscomp-wrapper{ .form .osui-monthpicker-ss-preview{ -servicestudio-margin-top:-22px; } -/*! 6.3.12. Notification */ +/*! 6.3.13. Notification */ .osui-notification{ --osui-notification-margin:var(--space-m); background-color:var(--color-neutral-0); @@ -9694,7 +9794,7 @@ body.vscomp-popup-active .vscomp-wrapper{ .android[data-status-bar-height] .layout-native .osui-notification--is-open{ margin-top:var(--status-bar-height); } -/*! 6.3.13. RangeSlider */ +/*! 6.3.14. RangeSlider */ .osui-range-slider{ --range-slider-handle-size:24px; --range-slider-thickness:4px; @@ -9908,7 +10008,7 @@ body.vscomp-popup-active .vscomp-wrapper{ .noUi-connects{ z-index:var(--layer-global-screen); } -/*! 6.3.14. Scrollable Area */ +/*! 6.3.15. Scrollable Area */ .scrollable-area-content{ --scrollable-area-height:auto; --scrollable-area-width:100%; @@ -9974,7 +10074,7 @@ body.vscomp-popup-active .vscomp-wrapper{ margin-left:unset; margin-right:var(--space-base); } -/*! 6.3.15. Search */ +/*! 6.3.16. Search */ .search{ position:relative; } @@ -10131,7 +10231,7 @@ body.vscomp-popup-active .vscomp-wrapper{ .fade-leave .header-right .layout-native .search-input{ display:none; } -/*! 6.3.16. Sidebar */ +/*! 6.3.17. Sidebar */ .osui-sidebar{ --overlay-opacity:0; background-color:var(--color-neutral-0); @@ -10279,7 +10379,7 @@ body.vscomp-popup-active .vscomp-wrapper{ .phone .osui-sidebar{ max-width:85vw; } -/*! 6.3.17. Stacked Cards */ +/*! 6.3.18. Stacked Cards */ .stackedcards{ position:relative; } @@ -10458,7 +10558,7 @@ body.vscomp-popup-active .vscomp-wrapper{ .stackedcards-overlay-hidden{ display:none; } -/*! 6.3.18. TimePicker */ +/*! 6.3.19. TimePicker */ .osui-timepicker__dropdown .numInputWrapper span.arrowUp:after{ border-bottom-color:var(--color-neutral-8); } @@ -10590,7 +10690,7 @@ html[data-uieditorversion^="1"] .osui-timepicker__dropdown-ss-preview.time12h, h .osui-timepicker__dropdown:before, .osui-timepicker__dropdown:after{ display:none; } -/*! 6.3.19. Video */ +/*! 6.3.20. Video */ .osui-video{ -servicestudio-background-image:url(""); -servicestudio-background-position:top center; @@ -10712,7 +10812,48 @@ html[data-uieditorversion^="1"] .osui-timepicker__dropdown-ss-preview.time12h, h margin:var(--space-none) var(--space-s); width:auto; } -/*! 6.4.3. Pagination */ +/*! 6.4.3. OverflowMenu */ +.osui-overflow-menu{ + --osui-overflow-menu-min-width:170px; + --border-radius-rounded:16px; +} +.osui-overflow-menu__trigger{ + --osui-floating-offset:var(--space-s); + border:var(--border-size-s) solid transparent; + border-radius:var(--osui-overflow-menu-shape); + color:var(--color-neutral-9); + width:32px; +} +.osui-overflow-menu__trigger *{ + pointer-events:none; +} +.osui-overflow-menu--is-open .osui-overflow-menu__trigger{ + background-color:var(--color-neutral-4); +} +.osui-overflow-menu__balloon{ + min-width:var(--osui-overflow-menu-min-width); +} +.osui-overflow-menu__balloon a{ + color:var(--color-neutral-9); +} +.osui-overflow-menu__balloon a:hover{ + background:var(--color-neutral-4); + text-decoration:none; +} +.osui-overflow-menu__balloon a{ + -servicestudio-align-items:center; + -servicestudio-display:inline-flex !important; + -servicestudio-color:var(--color-neutral-9); + -servicestudio-padding:var(--space-s) var(--space-base); +} +.osui-overflow-menu__balloon a:not([class^=padding-]){ + padding:var(--space-s) var(--space-base); +} +.tablet .osui-overflow-menu .osui-overflow-menu__trigger.btn, +.phone .osui-overflow-menu .osui-overflow-menu__trigger.btn{ + width:40px; +} +/*! 6.4.4. Pagination */ .pagination{ -webkit-box-align:center; -ms-flex-align:center; @@ -10837,7 +10978,7 @@ html[data-uieditorversion^="1"] .osui-timepicker__dropdown-ss-preview.time12h, h .has-accessible-features .pagination-button:focus{ border-color:var(--color-focus-inner); } -/*! 6.4.4. Section Index */ +/*! 6.4.5. Section Index */ .osui-section-index{ display:-webkit-box; display:-ms-flexbox; @@ -10917,7 +11058,7 @@ html[data-uieditorversion^="1"] .osui-timepicker__dropdown-ss-preview.time12h, h right:calc(var(--os-safe-area-right) + var(--space-base)); padding:0 0 var(--space-base) 0; } -/*! 6.4.5. Submenu */ +/*! 6.4.6. Submenu */ .osui-submenu{ cursor:pointer; display:-webkit-inline-box; @@ -11259,7 +11400,7 @@ html[data-uieditorversion^="1"] .osui-timepicker__dropdown-ss-preview.time12h, h margin-left:var(--space-none); margin-right:var(--space-s); } -/*! 6.4.6. Tabs */ +/*! 6.4.7. Tabs */ .osui-tabs{ --header-item-width:fit-content(30%); --header-item-alignment:auto; @@ -11594,7 +11735,7 @@ html[data-uieditorversion^="1"] .osui-tabs__preview--is-active::after{ -servicestudio-position:absolute; -servicestudio-width:100%; } -/*! 6.4.7. Timeline */ +/*! 6.4.8. Timeline */ .timeline-item{ display:-webkit-box; display:-ms-flexbox; @@ -11666,7 +11807,7 @@ html[data-uieditorversion^="1"] .osui-tabs__preview--is-active::after{ [data-block="Navigation.TimelineItem"]:last-of-type .timeline-icon-line{ display:none; } -/*! 6.4.8. Wizard */ +/*! 6.4.9. Wizard */ .wizard-wrapper.wizard-vertical [data-block*=WizardItem] .wizard-wrapper-item{ -webkit-box-align:center; -ms-flex-align:center; diff --git a/dist/OutSystemsUI.d.ts b/dist/OutSystemsUI.d.ts index 80cc2526c6..733a2a86b2 100644 --- a/dist/OutSystemsUI.d.ts +++ b/dist/OutSystemsUI.d.ts @@ -57,6 +57,7 @@ declare namespace OSFramework.OSUI.Constants { const Comma = ","; const EnableLogMessages = false; const EmptyString = ""; + const FocusTrapIgnoreAttr = "ignore-focus-trap"; const FocusableElems = "a[href]:not([disabled]),[tabindex=\"0\"], button:not([disabled]), textarea:not([disabled]), input[type=\"text\"]:not([disabled]), input[type=\"radio\"]:not([disabled]), input[type=\"checkbox\"]:not([disabled]),input[type=\"submit\"]:not([disabled]), select:not([disabled])"; const JavaScriptTypes: { Undefined: string; @@ -209,6 +210,27 @@ declare namespace OSFramework.OSUI.GlobalEnum { TopLeft = "top-left", TopRight = "top-right" } + enum FloatingAlignment { + Center = "center", + End = "end", + Start = "start" + } + enum FloatingPosition { + Auto = "auto", + Bottom = "bottom", + BottomStart = "bottom-start", + BottomEnd = "bottom-end", + Center = "center", + Left = "left", + LeftEnd = "left-end", + LeftStart = "left-start", + Right = "right", + RightEnd = "right-end", + RightStart = "right-start", + Top = "top", + TopStart = "top-start", + TopEnd = "top-end" + } enum CssProperties { Auto = "auto", Initial = "initial", @@ -292,6 +314,9 @@ declare namespace OSFramework.OSUI.GlobalEnum { TouchStart = "touchstart", TransitionEnd = "transitionend" } + enum CustomEvent { + BalloonOnToggle = "balloon.onToggle" + } enum InlineStyle { Display = "display", Height = "height", @@ -342,6 +367,7 @@ declare namespace OSFramework.OSUI.GlobalEnum { Accordion = "Accordion", AccordionItem = "Accordion Item", AnimatedLabel = "Animated Label", + Balloon = "Balloon", BottomSheet = "Bottom Sheet", ButtonLoading = "ButtonLoading", Carousel = "Carousel", @@ -355,6 +381,7 @@ declare namespace OSFramework.OSUI.GlobalEnum { InlineSvg = "InlineSVG", MonthPicker = "MonthPicker", Notification = "Notification", + OverflowMenu = "OverflowMenu", ProgressBar = "Progress Bar", ProgressCircle = "Progress Circle", RangeSlider = "Range Slider", @@ -569,11 +596,17 @@ declare namespace OSFramework.OSUI.Event.DOMEvents.Listeners { private _eventType; protected eventCallback: EventListenerObject; protected useCapture: boolean; - constructor(eventTarget: HTMLElement | Window, eventType: GlobalEnum.HTMLEvent); + constructor(eventTarget: HTMLElement | Document | Window, eventType: GlobalEnum.HTMLEvent | GlobalEnum.CustomEvent, isCustomEvent?: boolean); addEvent(): void; removeEvent(): void; } } +declare namespace OSFramework.OSUI.Event.DOMEvents.Listeners { + class BalloonOnToggle extends AbstractListener { + constructor(); + private _onToggleTrigger; + } +} declare namespace OSFramework.OSUI.Event.DOMEvents.Listeners { class BodyOnClick extends AbstractListener { private _enableBodyClick; @@ -604,6 +637,7 @@ declare namespace OSFramework.OSUI.Event.DOMEvents.Listeners { } declare namespace OSFramework.OSUI.Event.DOMEvents.Listeners { enum Type { + BalloonOnToggle = "balloon.onToggle", BodyOnClick = "body.onclick", BodyOnScroll = "body.onscroll", BodyOnMouseDown = "body.mousedown", @@ -800,6 +834,81 @@ declare namespace OSFramework.OSUI.Event.ProviderEvents { get hasPendingEvents(): boolean; } } +declare namespace OSFramework.OSUI.Feature { + abstract class AbstractFeature implements IFeature { + private _featureElem; + private _featureOptions; + private _featurePattern; + constructor(featurePattern: PT, featureElem: HTMLElement, options: O); + dispose(): void; + get featureElem(): HTMLElement; + get featureOptions(): O; + get featurePattern(): PT; + } +} +declare namespace OSFramework.OSUI.Feature { + interface IFeature extends Interface.IDisposable { + } +} +declare namespace OSFramework.OSUI.Feature.Balloon { + type BalloonOptions = { + alignment: GlobalEnum.FloatingAlignment; + allowedPlacements: Array; + anchorElem: HTMLElement; + position: GlobalEnum.FloatingPosition; + shape: GlobalEnum.ShapeTypes; + }; + class Balloon extends AbstractFeature implements IBalloon { + private _eventBodyClick; + private _eventOnKeypress; + private _floatingInstance; + private _floatingOptions; + private _focusTrapInstance; + private _focusableActiveElement; + private _isOpenedByApi; + private _onToggleEvent; + isOpen: boolean; + constructor(featurePattern: PT, featureElem: HTMLElement, options: BalloonOptions); + private _bodyClickCallback; + private _handleFocusTrap; + private _onkeypressCallback; + private _removeEventListeners; + private _setA11YProperties; + private _setCallbacks; + private _setEventListeners; + private _toggleBalloon; + private _unsetCallbacks; + build(): void; + close(): void; + dispose(): void; + open(isOpenedByApi: boolean): void; + setBalloonShape(shape?: GlobalEnum.ShapeTypes): void; + setFloatingBehaviour(isUpdate?: boolean): void; + setFloatingConfigs(): void; + updateFloatingConfigs(floatingConfigs?: Utils.FloatingPosition.FloatingPositionConfig): void; + updatePositionOption(position: GlobalEnum.FloatingPosition): void; + } +} +declare namespace OSFramework.OSUI.Feature.Balloon.Enum { + enum CssClasses { + IsOpen = "osui-balloon--is-open", + Pattern = "osui-balloon" + } + enum CssCustomProperties { + Shape = "--osui-balloon-shape" + } + enum Properties { + AnchorId = "AnchorId", + BalloonPosition = "BalloonPosition", + BalloonShape = "BalloonShape" + } +} +declare namespace OSFramework.OSUI.Feature.Balloon { + interface IBalloon extends Feature.IFeature, Interface.IOpenable { + setBalloonShape(shape?: GlobalEnum.ShapeTypes): void; + updatePositionOption(position: GlobalEnum.FloatingPosition): void; + } +} declare namespace OSFramework.OSUI.Helper { function AsyncInvocation(callback: GlobalCallbacks.Generic, ...args: unknown[]): void; function ApplySetTimeOut(callback: GlobalCallbacks.Generic, time: number, ...args: unknown[]): void; @@ -1024,6 +1133,10 @@ declare namespace OSFramework.OSUI.Interface { setGestureEvents(onGestureStart: Event.GestureEvent.Callbacks.GestureStart, onGestureMove: Event.GestureEvent.Callbacks.GestureMove, onGestureEnd: Event.GestureEvent.Callbacks.GestureEnd): any; } } +declare namespace OSFramework.OSUI.Interface { + interface IFloatable extends IOpenable { + } +} declare namespace OSFramework.OSUI.Interface { interface IGestureEvent { hasGestureEvents: boolean; @@ -1032,8 +1145,9 @@ declare namespace OSFramework.OSUI.Interface { } declare namespace OSFramework.OSUI.Interface { interface IOpenable { + isOpen?: boolean; close(): void; - open(): void; + open(isOpenedByApi?: boolean): void; } } declare namespace OSFramework.OSUI.Interface { @@ -2278,6 +2392,78 @@ declare namespace OSFramework.OSUI.Patterns.Notification { validateDefault(key: string, value: unknown): unknown; } } +declare namespace OSFramework.OSUI.Patterns.OverflowMenu.Callbacks { + type OSOnToggleEvent = { + (overflowMenuId: string, isOpen: boolean): void; + }; +} +declare namespace OSFramework.OSUI.Patterns.OverflowMenu.Enum { + enum AriaLabel { + Trigger = "Trigger the balloon" + } + enum CssClass { + Open = "osui-overflow-menu--is-open", + Trigger = "osui-overflow-menu__trigger", + Balloon = "osui-overflow-menu__balloon" + } + enum CssCustomProperties { + Shape = "--osui-overflow-menu-shape" + } + enum Events { + OnMenuToggle = "OnToggle" + } + enum Properties { + Position = "Position", + Shape = "Shape" + } +} +declare namespace OSFramework.OSUI.Patterns.OverflowMenu { + interface IOverflowMenu extends Interface.IPattern, Interface.IOpenable { + } +} +declare namespace OSFramework.OSUI.Patterns.OverflowMenu { + class OverflowMenu extends AbstractPattern implements IOverflowMenu { + private _ariaLabelTrigger; + private _balloonElem; + private _balloonFeature; + private _eventBalloonOnToggle; + private _eventOnClick; + private _isOpenedByApi; + private _platformEventOnToggle; + private _triggerElem; + balloonOptions: Feature.Balloon.BalloonOptions; + isOpen: boolean; + constructor(uniqueId: string, configs: JSON); + private _balloonOnToggleCallback; + private _onClickCallback; + private _setBalloonFeature; + private _setOverflowMenuShape; + private _togglePattern; + private _triggerOnToggleEvent; + protected removeEventListeners(): void; + protected setA11YProperties(): void; + protected setCallbacks(): void; + protected setEventListeners(): void; + protected setHtmlElements(): void; + protected unsetCallbacks(): void; + protected unsetHtmlElements(): void; + build(): void; + changeProperty(propertyName: string, propertyValue: unknown): void; + close(): void; + dispose(): void; + open(isOpenedByApi: boolean): void; + registerCallback(eventName: string, callback: GlobalCallbacks.OSGeneric): void; + setBalloonOptions(balloonOptions?: Feature.Balloon.BalloonOptions): void; + setTriggerAriaLabel(ariaLabelText: string): void; + } +} +declare namespace OSFramework.OSUI.Patterns.OverflowMenu { + class OverflowMenuConfig extends AbstractConfiguration { + Position: GlobalEnum.FloatingPosition; + Shape: GlobalEnum.ShapeTypes; + constructor(config: JSON); + } +} declare namespace OSFramework.OSUI.Patterns.Progress { abstract class AbstractProgress extends AbstractPattern implements IProgress { private _eventAnimateEntranceEnd; @@ -3537,6 +3723,49 @@ declare namespace OSFramework.OSUI.Patterns.Video { constructor(config: JSON); } } +declare namespace OSFramework.OSUI.Utils.FloatingPosition.Enum { + enum CssCustomProperties { + Offset = "--osui-floating-offset", + YPosition = "--osui-floating-position-y", + XPosition = "--osui-floating-position-x" + } + enum Provider { + FloatingUI = "FloatingUI" + } +} +declare namespace OSFramework.OSUI.Utils.FloatingPosition { + abstract class FloatingPosition implements IFloatingPosition { + protected eventOnUpdateCallback: OSFramework.OSUI.GlobalCallbacks.Generic; + protected floatingConfigs: FloatingPositionConfig; + protected isBuilt: boolean; + constructor(options: FloatingPositionConfig); + protected getOffsetValue(): number; + build(): void; + dispose(): void; + update(options: FloatingPositionConfig): void; + abstract setFloatingPosition(): void; + abstract unsetFloatingPosition(): void; + } +} +declare namespace OSFramework.OSUI.Utils.FloatingPosition { + class FloatingPositionConfig { + AnchorElem: HTMLElement; + AutoPlacement: boolean; + AutoPlacementOptions: AutoPlacementOptions; + FloatingElem: HTMLElement; + Position: string; + UpdatePosition: boolean; + } +} +declare namespace OSFramework.OSUI.Utils.FloatingPosition.Factory { + function NewFloatingPosition(configs: FloatingPositionConfig, provider: string): void; +} +declare namespace OSFramework.OSUI.Utils.FloatingPosition { + interface IFloatingPosition { + setFloatingPosition(): void; + unsetFloatingPosition(): void; + } +} declare namespace OutSystems.OSUI.ErrorCodes { const Success: { code: string; @@ -3814,6 +4043,13 @@ declare namespace OutSystems.OSUI.ErrorCodes { FailDispose: string; FailRegisterCallback: string; }; + const OverflowMenu: { + FailChangeProperty: string; + FailDispose: string; + FailRegisterCallback: string; + FailOpen: string; + FailClose: string; + }; const Video: { FailChangeProperty: string; FailClose: string; @@ -4021,6 +4257,17 @@ declare namespace OutSystems.OSUI.Patterns.NotificationAPI { function RegisterCallback(notificationId: string, eventName: string, callback: OSFramework.OSUI.GlobalCallbacks.OSGeneric): string; function Show(notificationId: string): string; } +declare namespace OutSystems.OSUI.Patterns.OverflowMenuAPI { + function ChangeProperty(overflowMenuId: string, propertyName: string, propertyValue: unknown): string; + function Create(overflowMenuId: string, configs: string): OSFramework.OSUI.Patterns.OverflowMenu.IOverflowMenu; + function Dispose(overflowMenuId: string): string; + function GetAllOverflowMenus(): Array; + function GetOverflowMenuById(overflowMenuId: string): OSFramework.OSUI.Patterns.OverflowMenu.IOverflowMenu; + function Initialize(overflowMenuId: string): OSFramework.OSUI.Patterns.OverflowMenu.IOverflowMenu; + function RegisterCallback(overflowMenuId: string, eventName: string, callback: OSFramework.OSUI.GlobalCallbacks.Generic): string; + function Open(overflowMenuId: string): string; + function Close(overflowMenuId: string): string; +} declare namespace OutSystems.OSUI.Patterns.ProgressAPI { function ChangeProperty(progressId: string, propertyName: string, propertyValue: any): string; function Create(progressId: string, type: string, configs: string): OSFramework.OSUI.Patterns.Progress.IProgress; @@ -4346,6 +4593,12 @@ declare namespace OutSystems.OSUI.Utils { function SetSelectedTableRow(TableId: string, RowNumber: number, IsSelected: boolean): string; function ShowPassword(): string; } +declare namespace Providers.OSUI.ErrorCodes { + const FloatingUI: { + FailCallProvider: string; + FailSetPosition: string; + }; +} declare namespace Providers { } declare namespace Providers.OSUI.Carousel.Splide.Enum { @@ -5707,3 +5960,21 @@ declare namespace Providers.OSUI.TimePicker.Flatpickr { interface IFlatpickrTime extends OSFramework.OSUI.Patterns.TimePicker.ITimePicker, OSFramework.OSUI.Interface.IProviderPattern { } } +declare namespace Providers.OSUI.Utils.Enum { + enum ProviderInfo { + Name = "FloatingUI", + Version = "1.2.8" + } +} +declare namespace Providers.OSUI.Utils { + class FloatingUI extends OSFramework.OSUI.Utils.FloatingPosition.FloatingPosition { + constructor(options: FloatingUIConfig); + dispose(): void; + setFloatingPosition(): void; + unsetFloatingPosition(): void; + } +} +declare namespace Providers.OSUI.Utils { + class FloatingUIConfig extends OSFramework.OSUI.Utils.FloatingPosition.FloatingPositionConfig { + } +} diff --git a/dist/OutSystemsUI.js b/dist/OutSystemsUI.js index b9ee058018..670216b66d 100644 --- a/dist/OutSystemsUI.js +++ b/dist/OutSystemsUI.js @@ -99,6 +99,7 @@ var OSFramework; Constants.Comma = ','; Constants.EnableLogMessages = false; Constants.EmptyString = ''; + Constants.FocusTrapIgnoreAttr = 'ignore-focus-trap'; Constants.FocusableElems = 'a[href]:not([disabled]),[tabindex="0"], button:not([disabled]), textarea:not([disabled]), input[type="text"]:not([disabled]), input[type="radio"]:not([disabled]), input[type="checkbox"]:not([disabled]),input[type="submit"]:not([disabled]), select:not([disabled])'; Constants.JavaScriptTypes = { Undefined: 'undefined', @@ -275,6 +276,29 @@ var OSFramework; Position["TopLeft"] = "top-left"; Position["TopRight"] = "top-right"; })(Position = GlobalEnum.Position || (GlobalEnum.Position = {})); + let FloatingAlignment; + (function (FloatingAlignment) { + FloatingAlignment["Center"] = "center"; + FloatingAlignment["End"] = "end"; + FloatingAlignment["Start"] = "start"; + })(FloatingAlignment = GlobalEnum.FloatingAlignment || (GlobalEnum.FloatingAlignment = {})); + let FloatingPosition; + (function (FloatingPosition) { + FloatingPosition["Auto"] = "auto"; + FloatingPosition["Bottom"] = "bottom"; + FloatingPosition["BottomStart"] = "bottom-start"; + FloatingPosition["BottomEnd"] = "bottom-end"; + FloatingPosition["Center"] = "center"; + FloatingPosition["Left"] = "left"; + FloatingPosition["LeftEnd"] = "left-end"; + FloatingPosition["LeftStart"] = "left-start"; + FloatingPosition["Right"] = "right"; + FloatingPosition["RightEnd"] = "right-end"; + FloatingPosition["RightStart"] = "right-start"; + FloatingPosition["Top"] = "top"; + FloatingPosition["TopStart"] = "top-start"; + FloatingPosition["TopEnd"] = "top-end"; + })(FloatingPosition = GlobalEnum.FloatingPosition || (GlobalEnum.FloatingPosition = {})); let CssProperties; (function (CssProperties) { CssProperties["Auto"] = "auto"; @@ -366,6 +390,10 @@ var OSFramework; HTMLEvent["TouchStart"] = "touchstart"; HTMLEvent["TransitionEnd"] = "transitionend"; })(HTMLEvent = GlobalEnum.HTMLEvent || (GlobalEnum.HTMLEvent = {})); + let CustomEvent; + (function (CustomEvent) { + CustomEvent["BalloonOnToggle"] = "balloon.onToggle"; + })(CustomEvent = GlobalEnum.CustomEvent || (GlobalEnum.CustomEvent = {})); let InlineStyle; (function (InlineStyle) { InlineStyle["Display"] = "display"; @@ -422,6 +450,7 @@ var OSFramework; PatternName["Accordion"] = "Accordion"; PatternName["AccordionItem"] = "Accordion Item"; PatternName["AnimatedLabel"] = "Animated Label"; + PatternName["Balloon"] = "Balloon"; PatternName["BottomSheet"] = "Bottom Sheet"; PatternName["ButtonLoading"] = "ButtonLoading"; PatternName["Carousel"] = "Carousel"; @@ -435,6 +464,7 @@ var OSFramework; PatternName["InlineSvg"] = "InlineSVG"; PatternName["MonthPicker"] = "MonthPicker"; PatternName["Notification"] = "Notification"; + PatternName["OverflowMenu"] = "OverflowMenu"; PatternName["ProgressBar"] = "Progress Bar"; PatternName["ProgressCircle"] = "Progress Circle"; PatternName["RangeSlider"] = "Range Slider"; @@ -1019,21 +1049,24 @@ var OSFramework; var Listeners; (function (Listeners) { class AbstractListener extends DOMEvents.AbstractEvent { - constructor(eventTarget, eventType) { + constructor(eventTarget, eventType, isCustomEvent = false) { super(); this.useCapture = false; this._eventTarget = eventTarget; this._eventType = eventType; - this._eventName = OSUI.GlobalEnum.HTMLEvent.Prefix + this._eventType; + this._eventName = isCustomEvent === false ? OSUI.GlobalEnum.HTMLEvent.Prefix + this._eventType : this._eventType; + if (isCustomEvent) { + window[this._eventName] = this._eventName; + } OSUI.Helper.AsyncInvocation(this.addEvent.bind(this)); } addEvent() { - if (this._eventName in window) { - this._eventTarget.addEventListener(this._eventType, this.eventCallback, this.useCapture); + if (this._eventName in window || window[this._eventName] !== undefined) { + this._eventTarget.addEventListener(this._eventType, this.eventCallback); } } removeEvent() { - if (this._eventName in window) { + if (this._eventName in window || window[this._eventName] !== undefined) { this._eventTarget.removeEventListener(this._eventType, this.eventCallback); } } @@ -1045,6 +1078,31 @@ var OSFramework; })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); })(OSFramework || (OSFramework = {})); var OSFramework; +(function (OSFramework) { + var OSUI; + (function (OSUI) { + var Event; + (function (Event) { + var DOMEvents; + (function (DOMEvents) { + var Listeners; + (function (Listeners) { + class BalloonOnToggle extends Listeners.AbstractListener { + constructor() { + super(document, OSUI.GlobalEnum.CustomEvent.BalloonOnToggle, true); + this.eventCallback = this._onToggleTrigger.bind(this); + } + _onToggleTrigger(evt) { + this.trigger(OSUI.GlobalEnum.CustomEvent.BalloonOnToggle, evt); + } + } + Listeners.BalloonOnToggle = BalloonOnToggle; + })(Listeners = DOMEvents.Listeners || (DOMEvents.Listeners = {})); + })(DOMEvents = Event.DOMEvents || (Event.DOMEvents = {})); + })(Event = OSUI.Event || (OSUI.Event = {})); + })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); +})(OSFramework || (OSFramework = {})); +var OSFramework; (function (OSFramework) { var OSUI; (function (OSUI) { @@ -1144,6 +1202,7 @@ var OSFramework; (function (Listeners) { let Type; (function (Type) { + Type["BalloonOnToggle"] = "balloon.onToggle"; Type["BodyOnClick"] = "body.onclick"; Type["BodyOnScroll"] = "body.onscroll"; Type["BodyOnMouseDown"] = "body.mousedown"; @@ -1168,6 +1227,8 @@ var OSFramework; class ListenerManager extends DOMEvents.AbstractEventsManager { getInstanceOfEventType(listenerType) { switch (listenerType) { + case Listeners.Type.BalloonOnToggle: + return new Listeners.BalloonOnToggle(); case Listeners.Type.BodyOnClick: return new Listeners.BodyOnClick(); case Listeners.Type.BodyOnScroll: @@ -1686,6 +1747,246 @@ var OSFramework; })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); })(OSFramework || (OSFramework = {})); var OSFramework; +(function (OSFramework) { + var OSUI; + (function (OSUI) { + var Feature; + (function (Feature) { + class AbstractFeature { + constructor(featurePattern, featureElem, options) { + this._featureOptions = options; + this._featureElem = featureElem; + this._featurePattern = featurePattern; + } + dispose() { + this._featureOptions = undefined; + this._featureElem = undefined; + } + get featureElem() { + return this._featureElem; + } + get featureOptions() { + return this._featureOptions; + } + get featurePattern() { + return this._featurePattern; + } + } + Feature.AbstractFeature = AbstractFeature; + })(Feature = OSUI.Feature || (OSUI.Feature = {})); + })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); +})(OSFramework || (OSFramework = {})); +var OSFramework; +(function (OSFramework) { + var OSUI; + (function (OSUI) { + var Feature; + (function (Feature) { + var Balloon; + (function (Balloon_1) { + class Balloon extends Feature.AbstractFeature { + constructor(featurePattern, featureElem, options) { + super(featurePattern, featureElem, options); + this._isOpenedByApi = false; + this.isOpen = false; + this.build(); + } + _bodyClickCallback(_args, e) { + var _a; + if (e.target === ((_a = this.featureOptions) === null || _a === void 0 ? void 0 : _a.anchorElem) || this._isOpenedByApi) { + return; + } + if (this.isOpen) { + this._toggleBalloon(false, true); + e.stopPropagation(); + } + } + _handleFocusTrap() { + const opts = { + focusTargetElement: this._floatingOptions.AnchorElem.parentElement, + }; + this._focusTrapInstance = new OSUI.Behaviors.FocusTrap(opts); + } + _onkeypressCallback(e) { + const isEscapedPressed = e.key === OSUI.GlobalEnum.Keycodes.Escape; + if (isEscapedPressed && this.isOpen) { + this.close(); + } + } + _removeEventListeners() { + this.featureElem.removeEventListener(OSUI.GlobalEnum.HTMLEvent.keyDown, this._eventOnKeypress); + OSUI.Event.DOMEvents.Listeners.GlobalListenerManager.Instance.removeHandler(OSUI.Event.DOMEvents.Listeners.Type.BodyOnClick, this._eventBodyClick); + } + _setA11YProperties() { + OSUI.Helper.Dom.Attribute.Set(this.featureElem, OSUI.Constants.A11YAttributes.Aria.Hidden, (!this.isOpen).toString()); + OSUI.Helper.A11Y.SetElementsTabIndex(this.isOpen, this._focusTrapInstance.focusableElements); + OSUI.Helper.Dom.Attribute.Set(this.featureElem, OSUI.Constants.A11YAttributes.TabIndex, this.isOpen + ? OSUI.Constants.A11YAttributes.States.TabIndexShow + : OSUI.Constants.A11YAttributes.States.TabIndexHidden); + OSUI.Helper.Dom.Attribute.Set(this._floatingOptions.AnchorElem, OSUI.Constants.A11YAttributes.TabIndex, this.isOpen + ? OSUI.Constants.A11YAttributes.States.TabIndexHidden + : OSUI.Constants.A11YAttributes.States.TabIndexShow); + } + _setCallbacks() { + this._eventBodyClick = this._bodyClickCallback.bind(this); + this._eventOnKeypress = this._onkeypressCallback.bind(this); + this._onToggleEvent = function dispatchCustomEvent(isOpen, balloonElem) { + const _customEvent = new CustomEvent(OSUI.GlobalEnum.CustomEvent.BalloonOnToggle, { + detail: { isOpen: isOpen, balloonElem: balloonElem }, + }); + document.dispatchEvent(_customEvent); + }; + } + _setEventListeners() { + this.featureElem.addEventListener(OSUI.GlobalEnum.HTMLEvent.keyDown, this._eventOnKeypress); + if (this.isOpen) { + OSUI.Event.DOMEvents.Listeners.GlobalListenerManager.Instance.addHandler(OSUI.Event.DOMEvents.Listeners.Type.BodyOnClick, this._eventBodyClick); + } + } + _toggleBalloon(isOpen, isBodyClick = false) { + this.isOpen = isOpen; + if (isOpen) { + OSUI.Helper.Dom.Styles.AddClass(this.featureElem, Balloon_1.Enum.CssClasses.IsOpen); + OSUI.Helper.AsyncInvocation(this._setEventListeners.bind(this)); + } + else { + OSUI.Helper.Dom.Styles.RemoveClass(this.featureElem, Balloon_1.Enum.CssClasses.IsOpen); + this._removeEventListeners(); + } + this._setA11YProperties(); + if (this.isOpen) { + this._focusableActiveElement = document.activeElement; + this._focusTrapInstance.enableForA11y(); + this.setFloatingBehaviour(); + OSUI.Helper.AsyncInvocation(() => { + this.featureElem.focus(); + }); + } + else { + this._focusTrapInstance.disableForA11y(); + this._floatingInstance.unsetFloatingPosition(); + OSUI.Helper.AsyncInvocation(() => { + this.featureElem.blur(); + if (isBodyClick === false) { + this._focusableActiveElement.focus(); + } + }); + } + this._onToggleEvent(this.isOpen, this.featureElem); + OSUI.Helper.AsyncInvocation(() => { + this._isOpenedByApi = false; + }); + } + _unsetCallbacks() { + this._eventBodyClick = undefined; + this._eventOnKeypress = undefined; + this._onToggleEvent = undefined; + window[OSFramework.OSUI.GlobalEnum.CustomEvent.BalloonOnToggle] = undefined; + } + build() { + this._setCallbacks(); + this._setEventListeners(); + this.setFloatingConfigs(); + this._handleFocusTrap(); + this._setA11YProperties(); + this.setBalloonShape(); + } + close() { + if (this.isOpen) { + this._toggleBalloon(false); + } + } + dispose() { + this._floatingInstance.dispose(); + this._unsetCallbacks(); + super.dispose(); + } + open(isOpenedByApi) { + if (this.isOpen === false) { + this._isOpenedByApi = isOpenedByApi; + this._toggleBalloon(true); + } + } + setBalloonShape(shape) { + if (shape !== undefined) { + this.featureOptions.shape = shape; + } + OSUI.Helper.Dom.Styles.SetStyleAttribute(this.featureElem, Balloon_1.Enum.CssCustomProperties.Shape, 'var(--border-radius-' + this.featureOptions.shape + ')'); + } + setFloatingBehaviour(isUpdate) { + if (isUpdate || this._floatingInstance === undefined) { + this.setFloatingConfigs(); + if (isUpdate && this._floatingInstance !== undefined) { + this._floatingInstance.update(this._floatingOptions); + } + else { + this._floatingInstance = new OSUI.Utils.FloatingPosition.Factory.NewFloatingPosition(this._floatingOptions, OSUI.Utils.FloatingPosition.Enum.Provider.FloatingUI); + } + } + else { + this._floatingInstance.build(); + } + } + setFloatingConfigs() { + this._floatingOptions = { + AutoPlacement: this.featureOptions.position === OSUI.GlobalEnum.FloatingPosition.Auto, + AnchorElem: this.featureOptions.anchorElem, + AutoPlacementOptions: { + alignment: this.featureOptions.alignment, + allowedPlacements: this.featureOptions.allowedPlacements, + }, + FloatingElem: this.featureElem, + Position: this.featureOptions.position, + UpdatePosition: true, + }; + } + updateFloatingConfigs(floatingConfigs) { + if (floatingConfigs !== undefined) { + this._floatingOptions = floatingConfigs; + } + this.setFloatingBehaviour(true); + } + updatePositionOption(position) { + this.featureOptions.position = position; + this.setFloatingBehaviour(true); + } + } + Balloon_1.Balloon = Balloon; + })(Balloon = Feature.Balloon || (Feature.Balloon = {})); + })(Feature = OSUI.Feature || (OSUI.Feature = {})); + })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); +})(OSFramework || (OSFramework = {})); +var OSFramework; +(function (OSFramework) { + var OSUI; + (function (OSUI) { + var Feature; + (function (Feature) { + var Balloon; + (function (Balloon) { + var Enum; + (function (Enum) { + let CssClasses; + (function (CssClasses) { + CssClasses["IsOpen"] = "osui-balloon--is-open"; + CssClasses["Pattern"] = "osui-balloon"; + })(CssClasses = Enum.CssClasses || (Enum.CssClasses = {})); + let CssCustomProperties; + (function (CssCustomProperties) { + CssCustomProperties["Shape"] = "--osui-balloon-shape"; + })(CssCustomProperties = Enum.CssCustomProperties || (Enum.CssCustomProperties = {})); + let Properties; + (function (Properties) { + Properties["AnchorId"] = "AnchorId"; + Properties["BalloonPosition"] = "BalloonPosition"; + Properties["BalloonShape"] = "BalloonShape"; + })(Properties = Enum.Properties || (Enum.Properties = {})); + })(Enum = Balloon.Enum || (Balloon.Enum = {})); + })(Balloon = Feature.Balloon || (Feature.Balloon = {})); + })(Feature = OSUI.Feature || (OSUI.Feature = {})); + })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); +})(OSFramework || (OSFramework = {})); +var OSFramework; (function (OSFramework) { var OSUI; (function (OSUI) { @@ -2389,7 +2690,9 @@ var OSFramework; } } static GetFocusableElements(element) { - return [...element.querySelectorAll(OSUI.Constants.FocusableElems)]; + const _focusableElems = element.querySelectorAll(OSUI.Constants.FocusableElems); + const _filteredElements = Array.from(_focusableElems).filter((element) => element.getAttribute(OSUI.Constants.FocusTrapIgnoreAttr) !== 'true'); + return [..._filteredElements]; } static Move(element, target) { if (element && target) { @@ -6777,6 +7080,235 @@ var OSFramework; })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); })(OSFramework || (OSFramework = {})); var OSFramework; +(function (OSFramework) { + var OSUI; + (function (OSUI) { + var Patterns; + (function (Patterns) { + var OverflowMenu; + (function (OverflowMenu) { + var Enum; + (function (Enum) { + let AriaLabel; + (function (AriaLabel) { + AriaLabel["Trigger"] = "Trigger the balloon"; + })(AriaLabel = Enum.AriaLabel || (Enum.AriaLabel = {})); + let CssClass; + (function (CssClass) { + CssClass["Open"] = "osui-overflow-menu--is-open"; + CssClass["Trigger"] = "osui-overflow-menu__trigger"; + CssClass["Balloon"] = "osui-overflow-menu__balloon"; + })(CssClass = Enum.CssClass || (Enum.CssClass = {})); + let CssCustomProperties; + (function (CssCustomProperties) { + CssCustomProperties["Shape"] = "--osui-overflow-menu-shape"; + })(CssCustomProperties = Enum.CssCustomProperties || (Enum.CssCustomProperties = {})); + let Events; + (function (Events) { + Events["OnMenuToggle"] = "OnToggle"; + })(Events = Enum.Events || (Enum.Events = {})); + let Properties; + (function (Properties) { + Properties["Position"] = "Position"; + Properties["Shape"] = "Shape"; + })(Properties = Enum.Properties || (Enum.Properties = {})); + })(Enum = OverflowMenu.Enum || (OverflowMenu.Enum = {})); + })(OverflowMenu = Patterns.OverflowMenu || (Patterns.OverflowMenu = {})); + })(Patterns = OSUI.Patterns || (OSUI.Patterns = {})); + })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); +})(OSFramework || (OSFramework = {})); +var OSFramework; +(function (OSFramework) { + var OSUI; + (function (OSUI) { + var Patterns; + (function (Patterns) { + var OverflowMenu; + (function (OverflowMenu_1) { + class OverflowMenu extends Patterns.AbstractPattern { + constructor(uniqueId, configs) { + super(uniqueId, new OverflowMenu_1.OverflowMenuConfig(configs)); + this._isOpenedByApi = false; + this.isOpen = false; + } + _balloonOnToggleCallback(_args, e) { + if (e.detail.balloonElem === this._balloonElem) { + this._togglePattern(e.detail.isOpen); + } + } + _onClickCallback() { + if (this._balloonFeature.isOpen) { + this.close(); + } + else { + this._isOpenedByApi = false; + this.open(this._isOpenedByApi); + } + } + _setBalloonFeature() { + this.setBalloonOptions(); + this._balloonFeature = new OSFramework.OSUI.Feature.Balloon.Balloon(this, this._balloonElem, this.balloonOptions); + } + _setOverflowMenuShape(shape) { + if (shape !== undefined) { + this.configs.Shape = shape; + } + OSUI.Helper.Dom.Styles.SetStyleAttribute(this.selfElement, OverflowMenu_1.Enum.CssCustomProperties.Shape, `var(--border-radius-${this.configs.Shape})`); + } + _togglePattern(isOpen) { + if (isOpen) { + OSUI.Helper.Dom.Styles.AddClass(this.selfElement, OverflowMenu_1.Enum.CssClass.Open); + } + else { + OSUI.Helper.Dom.Styles.RemoveClass(this.selfElement, OverflowMenu_1.Enum.CssClass.Open); + } + this.isOpen = isOpen; + this.setA11YProperties(); + this._triggerOnToggleEvent(); + } + _triggerOnToggleEvent() { + this.triggerPlatformEventCallback(this._platformEventOnToggle, this.isOpen); + } + removeEventListeners() { + this._triggerElem.removeEventListener(OSUI.GlobalEnum.HTMLEvent.Click, this._eventOnClick); + OSUI.Event.DOMEvents.Listeners.GlobalListenerManager.Instance.removeHandler(OSUI.Event.DOMEvents.Listeners.Type.BalloonOnToggle, this._eventBalloonOnToggle); + } + setA11YProperties() { + if (this.isBuilt === false) { + OSUI.Helper.A11Y.AriaHasPopupTrue(this.selfElement); + OSUI.Helper.A11Y.AriaControls(this._triggerElem, this._balloonElem.id); + this.setTriggerAriaLabel(OverflowMenu_1.Enum.AriaLabel.Trigger); + OSUI.Helper.Dom.Attribute.Set(this._triggerElem, OSUI.Constants.FocusTrapIgnoreAttr, true); + } + OSUI.Helper.A11Y.AriaExpanded(this.selfElement, this.isOpen.toString()); + } + setCallbacks() { + this._eventBalloonOnToggle = this._balloonOnToggleCallback.bind(this); + this._eventOnClick = this._onClickCallback.bind(this); + } + setEventListeners() { + this._triggerElem.addEventListener(OSUI.GlobalEnum.HTMLEvent.Click, this._eventOnClick); + OSUI.Event.DOMEvents.Listeners.GlobalListenerManager.Instance.addHandler(OSUI.Event.DOMEvents.Listeners.Type.BalloonOnToggle, this._eventBalloonOnToggle); + } + setHtmlElements() { + this._triggerElem = OSUI.Helper.Dom.ClassSelector(this.selfElement, OverflowMenu_1.Enum.CssClass.Trigger); + this._balloonElem = OSUI.Helper.Dom.ClassSelector(this.selfElement, OverflowMenu_1.Enum.CssClass.Balloon); + } + unsetCallbacks() { + this._eventBalloonOnToggle = undefined; + this._eventOnClick = undefined; + } + unsetHtmlElements() { + this._balloonElem = undefined; + this._triggerElem = undefined; + this._balloonFeature = undefined; + } + build() { + super.build(); + this.setHtmlElements(); + this.setA11YProperties(); + this._setBalloonFeature(); + this._setOverflowMenuShape(); + this.setCallbacks(); + this.setEventListeners(); + this.finishBuild(); + } + changeProperty(propertyName, propertyValue) { + super.changeProperty(propertyName, propertyValue); + if (this.isBuilt) { + switch (propertyName) { + case OverflowMenu_1.Enum.Properties.Position: + this._balloonFeature.updatePositionOption(propertyValue); + break; + case OverflowMenu_1.Enum.Properties.Shape: + this._setOverflowMenuShape(propertyValue); + this._balloonFeature.setBalloonShape(propertyValue); + break; + } + } + } + close() { + if (this._balloonFeature.isOpen) { + this._balloonFeature.close(); + } + } + dispose() { + this._balloonFeature.dispose(); + this.removeEventListeners(); + this.unsetCallbacks(); + this.unsetHtmlElements(); + super.dispose(); + } + open(isOpenedByApi) { + if (this._balloonFeature.isOpen === false) { + this._isOpenedByApi = isOpenedByApi; + this._balloonFeature.open(this._isOpenedByApi); + } + } + registerCallback(eventName, callback) { + switch (eventName) { + case Patterns.OverflowMenu.Enum.Events.OnMenuToggle: + if (this._platformEventOnToggle === undefined) { + this._platformEventOnToggle = callback; + } + else { + console.warn(`The ${OSUI.GlobalEnum.PatternName.OverflowMenu} already has the toggle callback set.`); + } + break; + default: + super.registerCallback(eventName, callback); + } + } + setBalloonOptions(balloonOptions) { + if (balloonOptions !== undefined) { + this.balloonOptions = balloonOptions; + } + else { + this.balloonOptions = { + alignment: OSUI.GlobalEnum.FloatingAlignment.Start, + allowedPlacements: [ + OSUI.GlobalEnum.FloatingPosition.BottomStart, + OSUI.GlobalEnum.FloatingPosition.BottomEnd, + OSUI.GlobalEnum.FloatingPosition.TopStart, + OSUI.GlobalEnum.FloatingPosition.TopEnd, + ], + anchorElem: this._triggerElem, + position: this.configs.Position, + shape: this.configs.Shape, + }; + } + } + setTriggerAriaLabel(ariaLabelText) { + if (ariaLabelText !== OSUI.Constants.EmptyString) { + this._ariaLabelTrigger = ariaLabelText; + OSUI.Helper.A11Y.AriaLabel(this._triggerElem, this._ariaLabelTrigger); + } + } + } + OverflowMenu_1.OverflowMenu = OverflowMenu; + })(OverflowMenu = Patterns.OverflowMenu || (Patterns.OverflowMenu = {})); + })(Patterns = OSUI.Patterns || (OSUI.Patterns = {})); + })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); +})(OSFramework || (OSFramework = {})); +var OSFramework; +(function (OSFramework) { + var OSUI; + (function (OSUI) { + var Patterns; + (function (Patterns) { + var OverflowMenu; + (function (OverflowMenu) { + class OverflowMenuConfig extends Patterns.AbstractConfiguration { + constructor(config) { + super(config); + } + } + OverflowMenu.OverflowMenuConfig = OverflowMenuConfig; + })(OverflowMenu = Patterns.OverflowMenu || (Patterns.OverflowMenu = {})); + })(Patterns = OSUI.Patterns || (OSUI.Patterns = {})); + })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); +})(OSFramework || (OSFramework = {})); +var OSFramework; (function (OSFramework) { var OSUI; (function (OSUI) { @@ -8424,8 +8956,8 @@ var OSFramework; this._isOpen = true; this._triggerOnToggleEvent(); if (this._clickOutsideToClose || (this.configs.HasOverlay && this._clickOutsideToClose === undefined)) { - OSUI.Event.DOMEvents.Listeners.GlobalListenerManager.Instance.addHandler(OSUI.Event.DOMEvents.Listeners.Type.BodyOnMouseDown, this._eventOverlayMouseDown); - OSUI.Event.DOMEvents.Listeners.GlobalListenerManager.Instance.addHandler(OSUI.Event.DOMEvents.Listeners.Type.BodyOnClick, this._eventOverlayClick); + OSUI.Event.DOMEvents.Listeners.GlobalListenerManager.Instance.addHandler(OSUI.Event.DOMEvents.Listeners.Type.BodyOnMouseDown, this._eventOverlayMouseDown.bind(this)); + OSUI.Event.DOMEvents.Listeners.GlobalListenerManager.Instance.addHandler(OSUI.Event.DOMEvents.Listeners.Type.BodyOnClick, this._eventOverlayClick.bind(this)); } } this.selfElement.focus(); @@ -8443,7 +8975,9 @@ var OSFramework; _overlayMouseDownCallback(_args, e) { const targetElem = e.target; this._clickedOutsideElement = true; - if (targetElem.closest('.osui-sidebar__header') || targetElem.closest('.osui-sidebar__content')) { + if (targetElem.closest(`${OSUI.Constants.Dot}${Sidebar_1.Enum.CssClass.Header}`) || + (targetElem.closest(`${OSUI.Constants.Dot}${Sidebar_1.Enum.CssClass.Content}`) && + this.selfElement.contains(targetElem) === false)) { this._clickedOutsideElement = false; } } @@ -11114,6 +11648,106 @@ var OSFramework; })(Patterns = OSUI.Patterns || (OSUI.Patterns = {})); })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); })(OSFramework || (OSFramework = {})); +var OSFramework; +(function (OSFramework) { + var OSUI; + (function (OSUI) { + var Utils; + (function (Utils) { + var FloatingPosition; + (function (FloatingPosition) { + var Enum; + (function (Enum) { + let CssCustomProperties; + (function (CssCustomProperties) { + CssCustomProperties["Offset"] = "--osui-floating-offset"; + CssCustomProperties["YPosition"] = "--osui-floating-position-y"; + CssCustomProperties["XPosition"] = "--osui-floating-position-x"; + })(CssCustomProperties = Enum.CssCustomProperties || (Enum.CssCustomProperties = {})); + let Provider; + (function (Provider) { + Provider["FloatingUI"] = "FloatingUI"; + })(Provider = Enum.Provider || (Enum.Provider = {})); + })(Enum = FloatingPosition.Enum || (FloatingPosition.Enum = {})); + })(FloatingPosition = Utils.FloatingPosition || (Utils.FloatingPosition = {})); + })(Utils = OSUI.Utils || (OSUI.Utils = {})); + })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); +})(OSFramework || (OSFramework = {})); +var OSFramework; +(function (OSFramework) { + var OSUI; + (function (OSUI) { + var Utils; + (function (Utils) { + var FloatingPosition; + (function (FloatingPosition_1) { + class FloatingPosition { + constructor(options) { + this.floatingConfigs = options; + this.build(); + } + getOffsetValue() { + return parseInt(getComputedStyle(this.floatingConfigs.AnchorElem).getPropertyValue(FloatingPosition_1.Enum.CssCustomProperties.Offset)); + } + build() { + this.setFloatingPosition(); + this.isBuilt = true; + } + dispose() { + this.isBuilt = false; + } + update(options) { + this.floatingConfigs = options; + this.setFloatingPosition(); + } + } + FloatingPosition_1.FloatingPosition = FloatingPosition; + })(FloatingPosition = Utils.FloatingPosition || (Utils.FloatingPosition = {})); + })(Utils = OSUI.Utils || (OSUI.Utils = {})); + })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); +})(OSFramework || (OSFramework = {})); +var OSFramework; +(function (OSFramework) { + var OSUI; + (function (OSUI) { + var Utils; + (function (Utils) { + var FloatingPosition; + (function (FloatingPosition) { + class FloatingPositionConfig { + } + FloatingPosition.FloatingPositionConfig = FloatingPositionConfig; + })(FloatingPosition = Utils.FloatingPosition || (Utils.FloatingPosition = {})); + })(Utils = OSUI.Utils || (OSUI.Utils = {})); + })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); +})(OSFramework || (OSFramework = {})); +var OSFramework; +(function (OSFramework) { + var OSUI; + (function (OSUI) { + var Utils; + (function (Utils) { + var FloatingPosition; + (function (FloatingPosition) { + var Factory; + (function (Factory) { + function NewFloatingPosition(configs, provider) { + let _floatingPositionItem = null; + switch (provider) { + case FloatingPosition.Enum.Provider.FloatingUI: + _floatingPositionItem = new Providers.OSUI.Utils.FloatingUI(configs); + break; + default: + throw new Error(`There is no FloatingPosition of the ${provider} provider`); + } + return _floatingPositionItem; + } + Factory.NewFloatingPosition = NewFloatingPosition; + })(Factory = FloatingPosition.Factory || (FloatingPosition.Factory = {})); + })(FloatingPosition = Utils.FloatingPosition || (Utils.FloatingPosition = {})); + })(Utils = OSUI.Utils || (OSUI.Utils = {})); + })(OSUI = OSFramework.OSUI || (OSFramework.OSUI = {})); +})(OSFramework || (OSFramework = {})); var OutSystems; (function (OutSystems) { var OSUI; @@ -11396,6 +12030,13 @@ var OutSystems; FailDispose: 'OSUI-API-29002', FailRegisterCallback: 'OSUI-API-29003', }; + ErrorCodes.OverflowMenu = { + FailChangeProperty: 'OSUI-API-30001', + FailDispose: 'OSUI-API-30002', + FailRegisterCallback: 'OSUI-API-30003', + FailOpen: 'OSUI-API-30004', + FailClose: 'OSUI-API-30005', + }; ErrorCodes.Video = { FailChangeProperty: 'OSUI-API-31001', FailClose: 'OSUI-API-31002', @@ -13096,6 +13737,98 @@ var OutSystems; })(OSUI = OutSystems.OSUI || (OutSystems.OSUI = {})); })(OutSystems || (OutSystems = {})); var OutSystems; +(function (OutSystems) { + var OSUI; + (function (OSUI) { + var Patterns; + (function (Patterns) { + var OverflowMenuAPI; + (function (OverflowMenuAPI) { + const _overflowMenuMap = new Map(); + function ChangeProperty(overflowMenuId, propertyName, propertyValue) { + const result = OutSystems.OSUI.Utils.CreateApiResponse({ + errorCode: OSUI.ErrorCodes.OverflowMenu.FailChangeProperty, + callback: () => { + const overflowMenu = GetOverflowMenuById(overflowMenuId); + overflowMenu.changeProperty(propertyName, propertyValue); + }, + }); + return result; + } + OverflowMenuAPI.ChangeProperty = ChangeProperty; + function Create(overflowMenuId, configs) { + if (_overflowMenuMap.has(overflowMenuId)) { + throw new Error(`There is already a ${OSFramework.OSUI.GlobalEnum.PatternName.OverflowMenu} registered under id: ${overflowMenuId}`); + } + const _overflowMenuItem = new OSFramework.OSUI.Patterns.OverflowMenu.OverflowMenu(overflowMenuId, JSON.parse(configs)); + _overflowMenuMap.set(overflowMenuId, _overflowMenuItem); + return _overflowMenuItem; + } + OverflowMenuAPI.Create = Create; + function Dispose(overflowMenuId) { + const result = OutSystems.OSUI.Utils.CreateApiResponse({ + errorCode: OSUI.ErrorCodes.OverflowMenu.FailDispose, + callback: () => { + const _overflowMenu = GetOverflowMenuById(overflowMenuId); + _overflowMenu.dispose(); + _overflowMenuMap.delete(_overflowMenu.uniqueId); + }, + }); + return result; + } + OverflowMenuAPI.Dispose = Dispose; + function GetAllOverflowMenus() { + return OSFramework.OSUI.Helper.MapOperation.ExportKeys(_overflowMenuMap); + } + OverflowMenuAPI.GetAllOverflowMenus = GetAllOverflowMenus; + function GetOverflowMenuById(overflowMenuId) { + return OSFramework.OSUI.Helper.MapOperation.FindInMap(OSFramework.OSUI.GlobalEnum.PatternName.OverflowMenu, overflowMenuId, _overflowMenuMap); + } + OverflowMenuAPI.GetOverflowMenuById = GetOverflowMenuById; + function Initialize(overflowMenuId) { + const _overflowMenu = GetOverflowMenuById(overflowMenuId); + _overflowMenu.build(); + return _overflowMenu; + } + OverflowMenuAPI.Initialize = Initialize; + function RegisterCallback(overflowMenuId, eventName, callback) { + const result = OutSystems.OSUI.Utils.CreateApiResponse({ + errorCode: OSUI.ErrorCodes.OverflowMenu.FailRegisterCallback, + callback: () => { + const _overflowMenu = GetOverflowMenuById(overflowMenuId); + _overflowMenu.registerCallback(eventName, callback); + }, + }); + return result; + } + OverflowMenuAPI.RegisterCallback = RegisterCallback; + function Open(overflowMenuId) { + const result = OutSystems.OSUI.Utils.CreateApiResponse({ + errorCode: OSUI.ErrorCodes.OverflowMenu.FailOpen, + callback: () => { + const _overflowMenuItem = GetOverflowMenuById(overflowMenuId); + _overflowMenuItem.open(true); + }, + }); + return result; + } + OverflowMenuAPI.Open = Open; + function Close(overflowMenuId) { + const result = OutSystems.OSUI.Utils.CreateApiResponse({ + errorCode: OSUI.ErrorCodes.OverflowMenu.FailClose, + callback: () => { + const _overflowMenuItem = GetOverflowMenuById(overflowMenuId); + _overflowMenuItem.close(); + }, + }); + return result; + } + OverflowMenuAPI.Close = Close; + })(OverflowMenuAPI = Patterns.OverflowMenuAPI || (Patterns.OverflowMenuAPI = {})); + })(Patterns = OSUI.Patterns || (OSUI.Patterns = {})); + })(OSUI = OutSystems.OSUI || (OutSystems.OSUI = {})); +})(OutSystems || (OutSystems = {})); +var OutSystems; (function (OutSystems) { var OSUI; (function (OSUI) { @@ -16024,6 +16757,19 @@ var OutSystems; })(OSUI = OutSystems.OSUI || (OutSystems.OSUI = {})); })(OutSystems || (OutSystems = {})); var Providers; +(function (Providers) { + var OSUI; + (function (OSUI) { + var ErrorCodes; + (function (ErrorCodes) { + ErrorCodes.FloatingUI = { + FailCallProvider: 'OSUI-PVR-01001', + FailSetPosition: 'OSUI-PVR-01002', + }; + })(ErrorCodes = OSUI.ErrorCodes || (OSUI.ErrorCodes = {})); + })(OSUI = Providers.OSUI || (Providers.OSUI = {})); +})(Providers || (Providers = {})); +var Providers; (function (Providers) { var OSUI; (function (OSUI) { @@ -19938,3 +20684,89 @@ var Providers; })(TimePicker = OSUI.TimePicker || (OSUI.TimePicker = {})); })(OSUI = Providers.OSUI || (Providers.OSUI = {})); })(Providers || (Providers = {})); +var Providers; +(function (Providers) { + var OSUI; + (function (OSUI) { + var Utils; + (function (Utils) { + var Enum; + (function (Enum) { + let ProviderInfo; + (function (ProviderInfo) { + ProviderInfo["Name"] = "FloatingUI"; + ProviderInfo["Version"] = "1.2.8"; + })(ProviderInfo = Enum.ProviderInfo || (Enum.ProviderInfo = {})); + })(Enum = Utils.Enum || (Utils.Enum = {})); + })(Utils = OSUI.Utils || (OSUI.Utils = {})); + })(OSUI = Providers.OSUI || (Providers.OSUI = {})); +})(Providers || (Providers = {})); +var Providers; +(function (Providers) { + var OSUI; + (function (OSUI) { + var Utils; + (function (Utils) { + class FloatingUI extends OSFramework.OSUI.Utils.FloatingPosition.FloatingPosition { + constructor(options) { + super(options); + } + dispose() { + if (this.floatingConfigs.UpdatePosition) { + this.eventOnUpdateCallback(); + } + super.dispose(); + } + setFloatingPosition() { + const _middlewareArray = []; + if (this.floatingConfigs.AutoPlacement) { + if (this.floatingConfigs.AutoPlacementOptions.alignment === OSFramework.OSUI.Constants.EmptyString) { + this.floatingConfigs.AutoPlacementOptions.alignment = null; + } + if (this.floatingConfigs.AutoPlacementOptions.allowedPlacements.length <= 0) { + this.floatingConfigs.AutoPlacementOptions.allowedPlacements.push(OSFramework.OSUI.GlobalEnum.FloatingPosition.BottomStart); + } + _middlewareArray.push(window.FloatingUIDOM.autoPlacement(this.floatingConfigs.AutoPlacementOptions)); + _middlewareArray.push(window.FloatingUIDOM.shift()); + } + if (this.floatingConfigs.Position !== OSFramework.OSUI.GlobalEnum.FloatingPosition.Center) { + _middlewareArray.push(window.FloatingUIDOM.offset(this.getOffsetValue())); + } + const _eventOnUpdatePosition = () => { + window.FloatingUIDOM.computePosition(this.floatingConfigs.AnchorElem, this.floatingConfigs.FloatingElem, { + placement: this.floatingConfigs.Position, + middleware: _middlewareArray, + }).then(({ x, y }) => { + OSFramework.OSUI.Helper.Dom.Styles.SetStyleAttribute(this.floatingConfigs.FloatingElem, OSFramework.OSUI.Utils.FloatingPosition.Enum.CssCustomProperties.YPosition, y + OSFramework.OSUI.GlobalEnum.Units.Pixel); + OSFramework.OSUI.Helper.Dom.Styles.SetStyleAttribute(this.floatingConfigs.FloatingElem, OSFramework.OSUI.Utils.FloatingPosition.Enum.CssCustomProperties.XPosition, x + OSFramework.OSUI.GlobalEnum.Units.Pixel); + }); + }; + _eventOnUpdatePosition(); + if (this.floatingConfigs.UpdatePosition) { + this.eventOnUpdateCallback = window.FloatingUIDOM.autoUpdate(this.floatingConfigs.AnchorElem, this.floatingConfigs.FloatingElem, _eventOnUpdatePosition.bind(this)); + } + } + unsetFloatingPosition() { + this.eventOnUpdateCallback(); + OSFramework.OSUI.Helper.ApplySetTimeOut(() => { + OSFramework.OSUI.Helper.Dom.Styles.SetStyleAttribute(this.floatingConfigs.FloatingElem, OSFramework.OSUI.Utils.FloatingPosition.Enum.CssCustomProperties.YPosition, 0); + OSFramework.OSUI.Helper.Dom.Styles.SetStyleAttribute(this.floatingConfigs.FloatingElem, OSFramework.OSUI.Utils.FloatingPosition.Enum.CssCustomProperties.XPosition, 0); + }, 50); + } + } + Utils.FloatingUI = FloatingUI; + })(Utils = OSUI.Utils || (OSUI.Utils = {})); + })(OSUI = Providers.OSUI || (Providers.OSUI = {})); +})(Providers || (Providers = {})); +var Providers; +(function (Providers) { + var OSUI; + (function (OSUI) { + var Utils; + (function (Utils) { + class FloatingUIConfig extends OSFramework.OSUI.Utils.FloatingPosition.FloatingPositionConfig { + } + Utils.FloatingUIConfig = FloatingUIConfig; + })(Utils = OSUI.Utils || (OSUI.Utils = {})); + })(OSUI = Providers.OSUI || (Providers.OSUI = {})); +})(Providers || (Providers = {})); diff --git a/src/scripts/OSFramework/OSUI/Pattern/Sidebar/Sidebar.ts b/src/scripts/OSFramework/OSUI/Pattern/Sidebar/Sidebar.ts index 671da408c0..c0c86b7d54 100644 --- a/src/scripts/OSFramework/OSUI/Pattern/Sidebar/Sidebar.ts +++ b/src/scripts/OSFramework/OSUI/Pattern/Sidebar/Sidebar.ts @@ -153,11 +153,11 @@ namespace OSFramework.OSUI.Patterns.Sidebar { if (this._clickOutsideToClose || (this.configs.HasOverlay && this._clickOutsideToClose === undefined)) { Event.DOMEvents.Listeners.GlobalListenerManager.Instance.addHandler( Event.DOMEvents.Listeners.Type.BodyOnMouseDown, - this._eventOverlayMouseDown + this._eventOverlayMouseDown.bind(this) ); Event.DOMEvents.Listeners.GlobalListenerManager.Instance.addHandler( Event.DOMEvents.Listeners.Type.BodyOnClick, - this._eventOverlayClick + this._eventOverlayClick.bind(this) ); } } @@ -187,7 +187,11 @@ namespace OSFramework.OSUI.Patterns.Sidebar { private _overlayMouseDownCallback(_args: string, e: MouseEvent): void { const targetElem = e.target as HTMLElement; this._clickedOutsideElement = true; - if (targetElem.closest('.osui-sidebar__header') || targetElem.closest('.osui-sidebar__content')) { + if ( + targetElem.closest(`${Constants.Dot}${Enum.CssClass.Header}`) || + (targetElem.closest(`${Constants.Dot}${Enum.CssClass.Content}`) && + this.selfElement.contains(targetElem) === false) + ) { // If the click was inside the side bar, then change the flag to false. this._clickedOutsideElement = false; } diff --git a/src/scss/OutSystemsUI.scss b/src/scss/OutSystemsUI.scss index ae111538b1..3e10e6f109 100644 --- a/src/scss/OutSystemsUI.scss +++ b/src/scss/OutSystemsUI.scss @@ -96,33 +96,35 @@ Section Index: 6.3.1. Action Sheet 6.3.2. Animate 6.3.3. Animated Label - 6.3.4. Bottom Sheet - 6.3.5. Carousel - 6.3.6. DatePicker - 6.3.7. Dropdown - 6.3.7.1 Dropdown Search - 6.3.7.2 Dropdown Tags - 6.3.8. Floating Actions - 6.3.9. Input With Icon - 6.3.10. Lightbox Image - 6.3.11. MonthPicker - 6.3.12. Notification - 6.3.13. RangeSlider - 6.3.14. Scrollable Area - 6.3.15. Search - 6.3.16. Sidebar - 6.3.17. Stacked Cards - 6.3.18. TimePicker - 6.3.19. Video + 6.3.4. Balloon + 6.3.5. Bottom Sheet + 6.3.6. Carousel + 6.3.7. DatePicker + 6.3.8. Dropdown + 6.3.8.1 Dropdown Search + 6.3.8.2 Dropdown Tags + 6.3.9. Floating Actions + 6.3.10. Input With Icon + 6.3.11. Lightbox Image + 6.3.12. MonthPicker + 6.3.13. Notification + 6.3.14. RangeSlider + 6.3.15. Scrollable Area + 6.3.16. Search + 6.3.17. Sidebar + 6.3.18. Stacked Cards + 6.3.19. TimePicker + 6.3.20. Video 6.4. Navigation 6.4.1. Bottom Bar Item 6.4.2. Breadcrumbs - 6.4.3. Pagination - 6.4.4. Section Index - 6.4.5. Submenu - 6.4.6. Tabs - 6.4.7. Timeline - 6.4.8. Wizard + 6.4.3. OverflowMenu + 6.4.4. Pagination + 6.4.5. Section Index + 6.4.6. Submenu + 6.4.7. Tabs + 6.4.8. Timeline + 6.4.9. Wizard 6.5. Numbers 6.5.1. Badge 6.5.2. Counter @@ -369,41 +371,43 @@ Functions & Mixins @import '04-patterns/03-interaction/animate'; /*! 6.3.3. Animated Label */ @import '../scripts/OSFramework/OSUI/Pattern/AnimatedLabel/scss/animated-label'; -/*! 6.3.4. Bottom Sheet */ +/*! 6.3.4. Balloon */ +@import '../scripts/OSFramework/OSUI/Feature/Balloon/scss/balloon'; +/*! 6.3.5. Bottom Sheet */ @import '../scripts/OSFramework/OSUI/Pattern/BottomSheet/scss/bottomsheet'; -/*! 6.3.5. Carousel */ +/*! 6.3.6. Carousel */ @import '../scripts/OSFramework/OSUI/Pattern/Carousel/scss/carousel'; -/*! 6.3.6. DatePicker */ +/*! 6.3.7. DatePicker */ @import '../scripts/OSFramework/OSUI/Pattern/DatePicker/scss/datepicker'; -/*! 6.3.7. Dropdown */ +/*! 6.3.8. Dropdown */ @import '../scripts/OSFramework/OSUI/Pattern/Dropdown/scss/dropdown'; -/*! 6.3.7.1 Dropdown Search */ +/*! 6.3.8.1 Dropdown Search */ @import '../scripts/OSFramework/OSUI/Pattern/Dropdown/scss/dropdown-search'; -/*! 6.3.7.2 Dropdown Tags */ +/*! 6.3.8.2 Dropdown Tags */ @import '../scripts/OSFramework/OSUI/Pattern/Dropdown/scss/dropdown-tags'; -/*! 6.3.8. Floating Actions */ +/*! 6.3.9. Floating Actions */ @import '04-patterns/03-interaction/floating-actions'; -/*! 6.3.9. Input With Icon */ +/*! 6.3.10. Input With Icon */ @import '04-patterns/03-interaction/input-with-icon'; -/*! 6.3.10. Lightbox Image */ +/*! 6.3.11. Lightbox Image */ @import '04-patterns/03-interaction/lightbox-image'; -/*! 6.3.11. MonthPicker */ +/*! 6.3.12. MonthPicker */ @import '../scripts/OSFramework/OSUI/Pattern/MonthPicker/scss/monthpicker'; -/*! 6.3.12. Notification */ +/*! 6.3.13. Notification */ @import '../scripts/OSFramework/OSUI/Pattern/Notification/scss/notification'; -/*! 6.3.13. RangeSlider */ +/*! 6.3.14. RangeSlider */ @import '../scripts/OSFramework/OSUI/Pattern/RangeSlider/scss/rangeslider'; -/*! 6.3.14. Scrollable Area */ +/*! 6.3.15. Scrollable Area */ @import '04-patterns/03-interaction/scrollable-area'; -/*! 6.3.15. Search */ +/*! 6.3.16. Search */ @import '04-patterns/03-interaction/search'; -/*! 6.3.16. Sidebar */ +/*! 6.3.17. Sidebar */ @import '../scripts/OSFramework/OSUI/Pattern/Sidebar/scss/sidebar'; -/*! 6.3.17. Stacked Cards */ +/*! 6.3.18. Stacked Cards */ @import '04-patterns/03-interaction/stacked-cards'; -/*! 6.3.18. TimePicker */ +/*! 6.3.19. TimePicker */ @import '../scripts/OSFramework/OSUI/Pattern/TimePicker/scss/timepicker'; -/*! 6.3.19. Video */ +/*! 6.3.20. Video */ @import '../scripts/OSFramework/OSUI/Pattern/Video/scss/video'; /*! 6.4. Navigation */ @@ -411,17 +415,19 @@ Functions & Mixins @import '04-patterns/04-navigation/bottom-bar-item'; /*! 6.4.2. Breadcrumbs */ @import '04-patterns/04-navigation/breadcrumbs'; -/*! 6.4.3. Pagination */ +/*! 6.4.3. OverflowMenu */ +@import '../scripts/OSFramework/OSUI/Pattern/OverflowMenu/scss/overflowmenu'; +/*! 6.4.4. Pagination */ @import '04-patterns/04-navigation/pagination'; -/*! 6.4.4. Section Index */ +/*! 6.4.5. Section Index */ @import '../scripts/OSFramework/OSUI/Pattern/SectionIndex/scss/sectionindex'; -/*! 6.4.5. Submenu */ +/*! 6.4.6. Submenu */ @import '../scripts/OSFramework/OSUI/Pattern/Submenu/scss/submenu'; -/*! 6.4.6. Tabs */ +/*! 6.4.7. Tabs */ @import '../scripts/OSFramework/OSUI/Pattern/Tabs/scss/tabs'; -/*! 6.4.7. Timeline */ +/*! 6.4.8. Timeline */ @import '04-patterns/04-navigation/timeline'; -/*! 6.4.8. Wizard */ +/*! 6.4.9. Wizard */ @import '04-patterns/04-navigation/wizard'; /*! 6.5. Numbers */