<protected> new Lookup()
- Since:
-
- 4.0.0 Added optional
cq-uppercaseattribute. - 7.4.0 Added optional
cq-exchangesattribute. - 8.3.0 Enabled internal keyboard navigation and selection.
- 9.1.0 Observes attributes. Added emitter.
- 4.0.0 Added optional
Example
Markup for lookup component
<cq-menu class="search ciq-lookup-icon" cq-focus="input" icon="ciq">
<cq-lookup cq-keystroke-claim cq-uppercase cq-exchanges="XNYS,XNAS,forex"></cq-lookup>
</cq-menu>
Extends
Members
-
context :CIQ.UI.Context
-
The current context node
Type:
- Inherited From:
- Overrides:
-
<static> markup :String
-
Default markup for the component's innerHTML, to be used when the component is added to the DOM without any innerHTML.
Type:
- String
Methods
-
acceptText(value, filter)
-
Performs the search of symbols based on the parameters input.
With the decoupling of the uiHelper to the Lookup.Driver you must be sure to include both an argument for maxResults and the closure to handle the results. maxResults must either be a number or a string to result in default value of 100.
Parameters:
Name Type Description valuestring String to search for.
filterstring Name of exchange to limit results to. The valid names are implementation-specific.
- Since:
-
3.0.0
-
addClaim()
-
Claim any keystrokes that come in. Once claimed, any keystrokes that come in are passed to the element. The element can then choose to capture or propagate the keystrokes. This enables an element to capture keystrokes even if it doesn't have mouse focus.
- Inherited From:
- Overrides:
-
addDefaultMarkup(component [, markup])
-
Adds default markup to a web component if the component does not have any child nodes.
Parameters:
Name Type Argument Description componentHTMLElement The component to which the markup is added.
markupString <optional>
The markup to add to the web component. Unused if the component has a static markup property that specifies the markup; for example, MyComponent.markup.
- Since:
-
7.5.0
- Inherited From:
- Overrides:
-
<protected> adoptedCallback()
-
- Inherited From:
- Overrides:
-
changeContext(newContext)
-
Called for a registered component when the context is changed in a multichart environment.
Parameters:
Name Type Description newContextCIQ.UI.Context The chart user interface context.
-
channelMergeObject(path, value, stx)
-
Merges an object in the chart engine communication channel.
Parameters:
Name Type Description pathString The channel path.
valueObject The value merged to the channel.
stxCIQ.ChartEngine A reference to the chart engine.
- Since:
-
7.5.0
- Inherited From:
- Overrides:
-
channelRead(path [, stx])
-
Reads the current value in the chart engine communication channel.
Parameters:
Name Type Argument Description pathString The channel path.
stxCIQ.ChartEngine <optional>
Unused.
- Since:
-
7.5.0
- Inherited From:
- Overrides:
Returns:
The current value in channel.
- Type
- *
-
channelSubscribe(path, cb, stx)
-
Subscribes to the chart engine messaging channel.
Parameters:
Name Type Description path* The channel path.
cb* A callback invoked upon subscribing and whenever a new message is posted in the channel.
stxCIQ.ChartEngine A reference to the chart engine.
- Since:
-
7.5.0
- Inherited From:
- Overrides:
Returns:
A callback invoked when unsubscribing from the channel.
- Type
- function
-
channelWrite(path, value, stx)
-
Writes in the chart engine communication channel.
Parameters:
Name Type Description pathString The channel path.
value* The value written to the channel.
stxCIQ.ChartEngine A reference to the chart engine.
- Since:
-
7.5.0
- Inherited From:
- Overrides:
-
chooseResult(params)
-
Closes the results list dropdown and passes the chosen symbol to be loaded onto the chart.
Parameters:
Name Type Description paramsobject Properties
Name Type Description nodeHTMLElement The element within the results list containing the chosen result.
-
clickFocusedItem(items, e)
-
Selects (clicks) the first element in
itemsthat has acq-focusedattribute.Parameters:
Name Type Description itemsNodeList A list of elements that are selectable via keyboard navigation.
eEvent The keystroke event.
- Since:
-
8.3.0
- Inherited From:
- Overrides:
-
close()
-
Closes the results list dropdown.
-
connectedCallback()
-
Convenience function that creates an array of injections for the component and sets a variable of node equal to self.
Designed to be used as a helper method for the included WebComponents. A full tutorial on how to work with and customize the WebComponents can be found here: Web Component Interface.
- Inherited From:
- Overrides:
-
deactivateItem(item)
-
Blurs and removes the
cq-keyboard-activeattribute fromitem.Parameters:
Name Type Description itemHTMLElement - Since:
-
8.4.0
- Inherited From:
- Overrides:
-
disconnectedCallback()
-
Removes all the the injections for a context tag and resets the tag to its default state.
Designed to be used as a helper method for the included WebComponents. A full tutorial on how to work with and customize the WebComponents can be found here: Web Component Interface.
- Inherited From:
- Overrides:
-
emitCustomEvent(params)
-
Emits a custom event from the webcomponent. The event type of the emitted event is determined by the particular user action taken. Up to two events are emitted when this function is executed. The first is an event with the type of action performed, if there is one. For example, events which are spawned without user action will not emit this first event. The second event will have a type derived from the component name. For example, the
cq-study-legendcomponent will emit a "StudyLegend" type event. The payload of the event will contain a detail section specifying the component which emitted the event as well as theeffect- which more clearly defines the type of action causing the emittance. The detail section may also include custom fields further categorizing the event and providing additional information. These details are documented within the web component's documentation.Parameters:
Name Type Description paramsobject Properties
Name Type Argument Default Description causestring <optional>
The cause of the event. e.g., useraction, timeout, alert. Defaults to "useraction" if not set and
actionparameter is set.effectstring <optional>
The effect of the user's action. Required if not provided in
detail. e.g., open, help, toggle, select.actionstring | null <optional>
"click" The action a user performed, if applicable. e.g. click, longpress, drag. Set to null if no user action was performed.
detailObject <optional>
{} Optional extra parameters to include in the detail of the Custom Event.
- Since:
-
- 8.9.0
- 9.1.0 Changed
paramsobject's property names.
- Inherited From:
- Overrides:
-
findFocused(items)
-
Finds the elements in
itemsthat have acq-focusedattribute.Parameters:
Name Type Description itemsNodeList A list of elements that are selectable via keyboard navigation.
- Since:
-
8.3.0
- Inherited From:
- Overrides:
Returns:
The elements in
itemsthat have acq-focusedattribute, or an empty array if no elements are found.- Type
- array
-
findKeyboardActive(items)
-
Finds the elements in
itemsthat have acq-keyboard-activeattribute.Parameters:
Name Type Description itemsNodeList A list of elements that are selectable via keyboard navigation
- Since:
-
8.4.0
- Inherited From:
- Overrides:
Returns:
The elements in
itemsthat have acq-keyboard-activeattribute, or an empty array if no elements are found.- Type
- Array
-
focusItem(item)
-
Adds a
cq-focusedattribute toitemand highlightsitem.Parameters:
Name Type Description itemHTMLElement Element that receives keyboard focus and is highlighted.
- Since:
-
8.3.0
- Inherited From:
- Overrides:
-
focusNextItem(items [, reverse] [, loop])
-
Focuses the next item in the tab order.
Locates the first element in
itemsthat has acq-focusedattribute. If an element is found, the attribute is removed from all elements initems, andcq-focusedis applied to the element that follows (in the tab order) the element that was found.If no elements are found with the
cq-focusedattribute, the attribute is applied to the first element initems(last element ifreverseis true). If the last element initems(first element ifreverseis true) is found to have thecq-focusedattribute, focus remains on that element. Unlessloopis set to true, then focus is applied to first element.Parameters:
Name Type Argument Description itemsNodeList A list of elements that are selectable via keyboard navigation.
reverseboolean <optional>
If true, the operation is performed in reverse order; that is, from the last element in
itemsto the first.loopboolean <optional>
Loops back to the first item if the last element in
itemsis selected.- Since:
-
8.4.0 Added loop parameter. Return element, instead of true, if focus is changed.
- Inherited From:
- Overrides:
- See:
Returns:
The newly focused element if a
cq-focusedattribute has changed.- Type
- HTMLElement | undefined
-
forceInput()
-
Takes whatever was input in the search box and uses it as the symbol to load the chart.
-
getChartContainer( [el])
-
Searches the DOM for the chart container element. Begins the search with
el(orthis) and proceeds parent-by-parent up the ancestry tree until an element is found.Parameters:
Name Type Argument Description elHTMLElement <optional>
The element on which to start the search. If not provided,
thisis used.- Since:
-
7.5.0
- Inherited From:
- Overrides:
Returns:
The chart container element or undefined if an element is not found.
- Type
- HTMLElement | undefined
-
getContextContainer( [el])
-
Searches the DOM for the chart context element. Begins the search with
el(orthisifelis not provided) and proceeds up the ancestry tree until an element is found or the root of the tree has been reached.Parameters:
Name Type Argument Description elHTMLElement <optional>
The element on which to start the search. If not provided,
thisis used.- Since:
-
7.5.0
- Inherited From:
- Overrides:
Returns:
The chart context element or undefined if an element is not found.
- Type
- HTMLElement | undefined
-
initialize()
-
Creates the markup of the component, and sets up event handlers.
-
inputEntry(node, cb)
-
Attaches a keyboard input entry event.
Parameters:
Name Type Description nodeHTMLElement The element to which the input entry event is attached.
cbfunction The callback function invoked when input entry occurs.
- Inherited From:
- Overrides:
-
isActive()
-
Returns active state of the search input box.
Returns:
True if active
- Type
- boolean
-
keyStroke(hub, key, e, keystroke)
-
Handler for keyboard interaction.
Note that this captures keystrokes on the body. If the input box is focused then we need to allow the input box itself to handle the strokes but we still want to capture them in order to display the lookup results. We first check activeElement to see if the input is focused. If so then we bypass logic that manipulates the input.value. In order make sure that the lookup menu is responding to an up-to-date input.value therefore we have to put all of those pieces of code in setTimeout(0)
Note that when comparisons are enabled, there are two Lookup components on the screen. Each keypress will therefore pass through this function twice, once for each Lookup component. Only the active component will process the keystroke.
Parameters:
Name Type Description hubCIQ.UI.KeystrokeHub The hub that processed the key
keystring Key that was stroked
eEvent The event object
keystrokeCIQ.UI.Keystroke Contains status of function keys
Returns:
true if keystroke was processed
- Type
- boolean
-
<protected> makeTap(node, cb)
-
Attaches an "stxtap" event to an element, which will be fired on any event that resembles a click or tap. Note only one stxtap event is allowed per element. The handler is saved on the element as the
selectFCproperty.Designed to be used as a helper method for the included WebComponents. A full tutorial on how to work with and customize the WebComponents can be found here: Web Component Interface.
Parameters:
Name Type Description nodeHTMLElement The element to attach a tap event to.
cbCIQ.makeTap~makeTapCallback The callback when tapped.
- Inherited From:
- Overrides:
-
onKeyboardDeselection()
-
Handler for when losing keyboard focus.
-
onKeyboardSelection()
-
Handler for when gaining keyboard focus.
-
open()
-
Opens the results list dropdown.
-
qs(path, context)
-
Adapts the querySelector method.
Parameters:
Name Type Description pathString The CSS selectors for which to search.
contextHTMLElement | String The chart context element, which is the starting point of the DOM query, or "thisChart" to indicate the chart context in which this function is called.
- Since:
-
7.5.0
- Inherited From:
- Overrides:
Returns:
The selected DOM element or undefined if an element is not found.
- Type
- HTMLElement | undefined
-
qsa(path, root, bustShadowRoots)
-
Adapts the querySelectorAll method. Returns an array instead of a node list to enable chaining of the array
map,filter,forEach, andreducefunctions.Parameters:
Name Type Description pathString The CSS selectors to find.
rootHTMLElement | String The root element, which is the starting point of the DOM query, or "thisChart" to indicate the chart context in which this function is called.
bustShadowRootsboolean Set to true to penetrate shadow root boundaries.
- Since:
-
- 7.5.0
- 8.9.0 Added
bustShadowRootsparameter
- Inherited From:
- Overrides:
Returns:
An array of selected DOM element.
- Type
- Array.<HTMLElement>
-
removeClaim()
-
Remove a claim on keystrokes.
- Inherited From:
- Overrides:
-
removeFocused(items)
-
Removes the
cq-focusedattribute from all elements initems.Parameters:
Name Type Description itemsNodeList A list of elements that are selectable via keyboard navigation.
- Since:
-
8.3.0
- Inherited From:
- Overrides:
-
reset()
-
Clear out the input and results list.
-
results(arr)
-
Displays an array of results returned by the CIQ.ChartEngine.Driver.Lookup.
Each element in the array should be in the following format (see CIQ.ChartEngine.Driver.Lookup#acceptText):
{ display: ["symbol ID", "symbol description", "exchange"], data: { symbol: "symbol ID", name: "symbol description", exchDisp: "exchange" } }The lookup component by default displays three columns as represented by the array. The data object can be a format required by your quote feed, or it can be a simple string if you just need to support a stock symbol.
Parameters:
Name Type Description arrArray.<object> The array of results.
-
selectItem(data, fn)
-
Accepts a new symbol or symbol object.
Parameters:
Name Type Description dataobject Contains a symbol or symbol object in a form accepted by CIQ.ChartEngine#loadChart.
fnfunction Function to execute when the callback set by setCallback finishes.
- Since:
-
8.2.0 Removed the
paramsparameter. Added thefnparameter.
-
setCallback(cb)
-
Sets a callback function to be called when the user selects a symbol.
Parameters:
Name Type Description cbfunction The callback function; for example, an implementation of CIQ.UI.Context#changeSymbol.
-
setContext(context)
-
Called for a registered component when the context is constructed. Sets the context property of the component.
Parameters:
Name Type Description contextCIQ.UI.Context The chart user interface context.
- Overrides:
-
setContextHolder()
-
Stores the component in the context holder (an array associated with the
cq-contextelement) so that when the context is started, it knows that this tag is contextual.Designed to be used as a helper method for the included WebComponents. A full tutorial on how to work with and customize the WebComponents can be found here: Web Component Interface.
- Inherited From:
- Overrides:
-
setDriver(driver)
-
Connects a CIQ.ChartEngine.Driver.Lookup to the web component.
The lookup driver searches financial exchanges for symbols that match the text entered in the component's input field.
Parameters:
Name Type Description driverCIQ.ChartEngine.Driver.Lookup The lookup driver to connect to the web component.
-
trimInnerHTMLWhitespace()
-
Returns a copy of the innerHTML of an element, with leading and trailing characters stripped. The following characters are stripped: newline, carriage return, tab.
- Since:
-
9.1.0
- Inherited From:
- Overrides:
Returns:
Trimmed innerHTML
- Type
- String
