Floater extends KompElement

Render content on a layer above an anchored element.

Example

JS
new Floater({
    content: "Hello World",
    anchor: '#hi-button'
})
HTML
<komp-floater anchor="#hi-button">
    Hello World
</komp-floater>

Constructor

new Floater(options)
options : Object optional
anchor : HTMLElement

element to anchor positioning to

container : string | HTMLElement optional

element to append floater to. If String, then used as selector for this.closest(selector)

placement : string optional

how the floater is anchored, e.g. "top", "top-start", "top-end", "left", "left-start"...

strategy : string optional

how the floater is positioned in the document. "absolute" or "fixed"

flip : boolean | Object optional

See https://floating-ui.com/docs/flip, defaults to false in favor of autoPlacement

offset : boolean | Object optional
shift : boolean | Object optional
arrow : boolean | number optional

True to show default size, or number in pixels

size : boolean | Object optional
autoPlacement : boolean | Object optional
inline : boolean | Object optional
autoUpdate : boolean | Object optional
removeOnBlur : boolean optional

hide floater on outside click/focus or escape key

timeout : number optional

ms to wait until hiding after mouseout

onShow : function optional

event listener for show (cancellable, fires before showing)

onShown : function optional

event listener for shown (fires after showing)

onHide : function optional

event listener for hide (cancellable, fires before hiding)

onHidden : function optional

event listener for hidden (fires after hiding)

scope : string optional

showing a floater will hide all other floaters of same scope

content : string | HTMLElement | Array | Object optional

content to append to element. Passed to Dolla's content

Properties

showing : boolean

is floater showing, can be disconnected and not showing in case of Tooltip

Static Properties

Attributes settable via constructor options. Each key is the attribute name and the value is a schema object describing how to handle it.

Example

static assignableAttributes = {
    anchor: { type: 'HTMLElement', default: null, null: true },
    placement: { type: 'string', default: 'bottom', null: false },
    enabled: { type: 'boolean', default: true, null: false },
    data: { type: 'array', default: [], null: false }
}

Properties

type : string | Array.<string>

expected type(s): 'string', 'number', 'boolean', 'object', 'array', 'function', or a class/element name like 'HTMLElement'

default : *

default value when none is provided

null : boolean

whether null is an acceptable value

load : function optional

optional transform applied when reading the attribute value

Methods overridable via constructor options

Methods to auto-bind to this

Event names that can be bound via onEventName constructor options

CSS injected once per component via adoptedStyleSheets

CSS @layer name used to wrap the component's styles when injected via adoptedStyleSheets. Set to a falsy value to disable layering.

Attributes to observe for changes. Triggers changed(attribute, was, now) and [attribute]Changed(was, now) callbacks.

Instance Methods

Listen for events on another element, automatically cleaned up when this component disconnects

Parameters

element : HTMLElement

element to listen on

eventType : string

event type

args : *

additional arguments passed to addEventListener

Called every time an observed attribute changes. Attribute must be listed in static watch.

Parameters

attribute : string

the attribute that changed

was : *

previous value

now : *

new value

Called when element is connected to the DOM

Called when element is disconnected from the DOM

Called once per instantiation, but only after element is connected to the DOM

Remove element. Fires remove, calls optional callback, removes from DOM, then fires removed.

Parameters

callback : function optional

async callback called between remove and removed

Returns

Toggle the floater visibility

Parameters

shouldHide : boolean optional

explicitly show or hide. If omitted, toggles based on current visibility.

Returns

Floater

this

Trigger an event on this element

Parameters

eventName : string

event name to trigger

args : *

additional arguments

Events

Fired before the element is connected to the DOM (cancellable)

Fired after the element is connected to the DOM and initialized

Fired before the element is disconnected from the DOM (cancellable)

Fired after the element is disconnected from the DOM

Fired after the floater is hidden

E   hide

Fired before the floater is hidden (cancellable)

Fired before the element is removed (cancellable)

Fired after the element is removed

E   show

Fired before the floater is shown (cancellable)

Fired after the floater is shown

Notes

Transition Animation

The floater will follow the transition effects set by CSS, and adds classes -out, -out-start, -in and -in-start when hiding and showing. Additionally, the floater adds classes for placement -left, -right, -top, -bottom.