Below is the list of methods that the widget supports. You can call them using the widget object that is returned to you by the widget's constructor.
Remark: Please note that it's safe to call any method only after onChartReady callback function is called.
Example:
widget.onChartReady(function() {
// It's now safe to call any other methods of the widget
});
- Subscribing To Chart Events
- Chart Actions
- Saving/Loading Charts
- Custom UI Controls
- Dialogs
- Getters
- Customization
- 💹 Trading Terminal only
- 💹 Multiple Charts Layout
callback
: function()
The Charting Library will call the callback function 1 time when chart is initialized. You can safely call all other methods starting from this moment.
Returns a Promise
object that should be used to handle an event when the Charting Library header widget API is ready (e.g. createButton).
callback
: function(subject)subject
: object{type, name}
type
:drawing
|study
name
: string, name of a clicked subject
The Library will call the callback
function every time a user clicks on a grayed out object.
Example:
new TradingView.widget({
drawings_access: {
type: "black",
tools: [
{ name: "Trend Line" },
{ name: "Trend Angle", grayed: true },
]
},
studies_access: {
type: "black",
tools: [
{ name: "Aroon" },
{ name: "Balance of Power", grayed: true },
]
},
<...> // other widget settings
});
widget.onChartReady(function() {
widget.onGrayedObjectClicked(function(data) {
// this function will be called when a user tries to
// create the Balance Of Power study or the Trend Angle shape
alert(data.name + " is grayed out!");
})
});
shortcut
callback
: function(data)
The Library will call the callback
function every time the shortcut key is pressed.
Example:
widget.onShortcut("alt+s", function() {
widget.executeActionById("symbolSearch");
});
event
: can be
Event name | Library Version | Description |
---|---|---|
toggle_sidebar |
Drawing toolbar is shown/hidden | |
indicators_dialog |
Indicators dialog is shown | |
toggle_header |
Chart header is shown/hidden | |
edit_object_dialog |
Chart/Study Properties dialog is shown | |
chart_load_requested |
New chart is about to be loaded | |
chart_loaded |
||
mouse_down |
||
mouse_up |
||
drawing |
1.7 | A drawing is added to a chart. The arguments contain an object with the value field that corresponds with the name of the drawing. |
study |
1.7 | An indicator is added to a chart.The arguments contain an object with the value field that corresponds with the name of the indicator. |
undo |
1.7 | |
redo |
1.7 | |
undo_redo_state_changed |
1.14 | The Undo/Redo state has been changed. The arguments contain an object with the state of the Undo/Redo stack. This object has the same structure as the result of UndoRedoState method |
reset_scales |
1.7 | Reset scales button is clicked |
compare_add |
1.7 | A compare dialog is shown |
add_compare |
1.7 | A compare instrument is added |
load_study template |
1.7 | A study template is loaded |
onTick |
Last bar is updated | |
onAutoSaveNeeded |
User changed the chart. Chart change means any user action that can be undone. The callback function will not be called more than once every 5 seconds. See also auto_save_delay |
|
onScreenshotReady |
A screenshot URL is returned by the server | |
onMarkClick |
User clicked a mark on a bar. Mark ID will be passed as an argument | |
onTimescaleMarkClick |
User clicked a timescale mark. Mark ID will be passed as an argument | |
onSelectedLineToolChanged |
Selected line tool is changed | |
study_properties_changed |
1.14 | Study properties are changed. Entity ID will be passed as an argument |
💹 layout_about_to_be_changed |
Amount or placement of the charts is about to be changed | |
💹 layout_changed |
Amount or placement of the charts is changed | |
💹 activeChartChanged |
Active chart is changed |
callback
: function(arguments)
The library will call the callback
function when a GUI event
has happened.
Every event can have a different set of arguments.
Unsubscribes a previously subscribed callback
function from a given event
(that is one of the events in the table above).
Returns a chart object that you can use to call Chart-Methods
locale
: language code
Sets the language of the widget. For now, this call reloads the chart. Please avoid using it.
symbol
: stringinterval
: stringcallback
: function()
Changes the symbol and resolution of the chart. The callback
function is called only when new symbol's data has been received.
Removes the chart widget from the web page.
Calling this method closes all context menus, pop-ups or dialogs.
drawingId
: may be one of the identifiers orcursor
dot
arrow_cursor
eraser
measure
zoom
brush
Selects a drawing or a cursor. It's the same as a single click on a drawing button.
Returns an identifier of the selected drawing or cursor (see above).
This method creates a snapshot of the chart and uploads it to the server. When it is done the onScreenshotReady callback function is called. The URL of the snapshot will be passed as an argument to the callback function.
This method returns a WatchedValue object that can be used to read/set/watch the state of Lock All Drawing Tools button.
This method returns a WatchedValue object that can be used to read/set/watch the state of Hide All Drawing Tools button.
callback
: function(object)
Saves the chart state to JS object. Charting Library will call your callback function and pass the state object as an argument.
This call is part of the low-level save/load API.
state
: object
Loads the chart from the state
object. This call is part of the low-level save/load API.
callback
: function(objects)
objects
is an array of:
id
name
image_url
modified_iso
short_symbol
interval
Returns a list of chart descriptions saved to the server for the current user.
chartRecord
is an object that you get using getSavedCharts(callback)
Loads and displays a chart from the server.
onCompleteCallback
: function()onFailCallback
: function()saveAsSnapshot
: should be alwaysfalse
options
: object{ chartName }
chartName
: name of a chart. Should be specified for new charts and when renaming the chart.defaultChartName
: default name of a chart. It will be used if the current chart has no name.
Saves the current chart to the server.
chartId
: theid
should be received from the object that is returned by the getSavedCharts(callback)onCompleteCallback
: function()
Removes the chart from the server.
callback
: function(unixtime, price). This callback function is expected to return a value (see below).
The Charting Library will call the callback function every time user opens a context menu on the chart. The arguments that are passed to the callback function contain unix time and price of the clicked point on the chart.
You have to return an array of objects that have the following format to add or remove items from the context menu.
{
position: 'top' | 'bottom',
text: 'Menu item text',
click: <onItemClicked callback>
}
position
: position of the item in the context menutext
: menu item textclick
: a callback function that will be called when a user selects your menu item
Use the minus sign to add a separator. Example: { text: "-", position: "top" }
.
Use the minus sign in front of the item text to remove an existing item from the menu.
Example:
widget.onChartReady(function() {
widget.onContextMenu(function(unixtime, price) {
return [{
position: "top",
text: "First top menu item, time: " + unixtime + ", price: " + price,
click: function() { alert("First clicked."); }
},
{ text: "-", position: "top" },
{ text: "-Objects Tree..." },
{
position: "top",
text: "Second top menu item 2",
click: function() { alert("Second clicked."); }
}, {
position: "bottom",
text: "Bottom menu item",
click: function() { alert("Third clicked."); }
}];
});
options
: object{ align: "left" }
align
:right
|left
. default:left
Creates a new DOM element in the top toolbar of the chart and returns HTMLElement for this button. You can use it to add custom controls right on the chart.
NOTE: This method MUST be called after headerReady promise is resolved.
Example:
widget.headerReady().then(function() {
var button = widget.createButton();
button.setAttribute('title', 'My custom button tooltip');
button.addEventListener('click', function() { alert("My custom button pressed!"); });
button.textContent = 'My custom button caption';
});
Starting from version 1.6.
params
: object:title
: text to be shown in the titlebody
: text to be shown in the bodycallback
: function to be called when ok button is pressed
This method shows a dialog with custom title and text along with the "OK" button.
params
: object:title
: text to be shown in the titlebody
: text to be shown in the bodycallback(result)
: function to be called when ok button is pressed.result
istrue
ifOK
is pressed, otherwise it isfalse
.
This method shows a dialog with the custom title and text along with the "OK" and "CANCEL" buttons.
Displays the "Load chart layout" dialog.
Displays the "Copy chart layout" dialog.
Charting Library returns an object that contains the symbol and interval of the chart.
Returns an object with the format
method that you can use to format the prices. This was introduced in version 1.5.
Returns an array of supported resolutions. This was introduced in version 1.7.
Returns an array of IDs of all studies. They can be used to create a study.
Returns an object with the state of the Undo/Redo stack. The object has the following keys:
* `enableUndo`: boolean flag that shows the undo action availability
* `undoText`: name of the next undo operation. If the undo stack is empty then it is undefined.
* `enableRedo`: boolean flag that shows the redo action availability
* `redoText`: name of the next redo operation. If the redo stack is empty then it is undefined.
Starting from version 1.13.
themeName
should be"Light"
|"Dark"
This method changes the chart theme without reloading the chart.
You can also use the theme in the Widget Constructor to create the chart with a custom theme.
url
should be an absolute or relative path to the 'static` folder
This method was introduced in version 1.3
.
Starting from version 1.4
use custom_css_url instead.
Starting from version 1.5.
overrides
is an object. It is the same as overrides in the Widget Constructor.
This method applies "overrides" to the properties without reloading the chart.
Starting from version 1.9.
overrides
is an object. It is the same as studies_overrides in the Widget Constructor.
This method applies "overrides" to the styles or inputs of the indicators without reloading the chart.
The following methods are available in Trading Terminal only.
Starting from version 1.9.
Returns an object to manage the watchlist. The object has the following methods:
-
defaultList()
- allows you to get a default list of symbols. -
getList(id?: string)
- allows you to get a list of symbols. If theid
parameter is not provided then the current list will be returned. If there is no WatchList thennull
will be returned. -
getActiveListId()
- allows you to get the ID of the current list. If there is no WatchList thennull
will be returned. -
getAllLists()
- allows you to get all lists. If there is no WatchList thennull
will be returned. -
setList(symbols: string[])
- allows you to set a list of symbols into the watchlist. It will replace the entire list. Obsolete. Will be removed in version1.13
. UseupdateList
instead. -
updateList(listId: string, symbols: string[])
- allows you to edit the list of symbols. -
renameList(listId: string, newName: string)
- allows you to rename the list tonewName
. -
createList(listName?: string, symbols?: string[])
- allows you to create a list of symbols withlistName
name. If thelistName
parameter is not provided or there is no WatchList thennull
will be returned; -
saveList(list: SymbolList)
- allows you to save a list of symbols wherelist
is an object with the following keys:id: string; title: string; symbols: string[];
If there is no WatchList or an equivalent list already exists then
false
will be returned, otherwisetrue
will returned. -
deleteList(listId: string)
- allows you to delete a list of symbols. -
onListChanged()
- you can use this method to be notified when the symbols of the active watchlist are changed. You can subscribe and unsubscribe using the [[Subscription]] object returned by this function. -
onActiveListChanged()
- you can use this method to be notified when a different list of the watchlist is selected. You can subscribe and unsubscribe using the [[Subscription]] object returned by this function. -
onListAdded()
- - you can use this method to be notified when the new list is added to the watchlist. You can subscribe and unsubscribe using the [[Subscription]] object returned by this function. -
onListRemoved()
- you can use this method to be notified when the list is removed from the watchlist. You can subscribe and unsubscribe using the [[Subscription]] object returned by this function. -
onListRenamed()
- - you can use this method to be notified when the list is renamed in the watchlist. You can subscribe and unsubscribe using the [[Subscription]] object returned by this function.
index
: index of a chart starting from0
.index
is0
by default.
Returns a chart object that you can use to call Chart-Methods
Returns a chart object of the active chart that you can use to call Chart-Methods
Returns the amount of charts in the current layout.
Returns the current layout mode. Possible values are: 4
, 6
, 8
, s
, 2h
, 2-1
, 2v
, 3h
, 3v
, 3s
.
layout
: Possible values are:4
,6
,8
,s
,2h
,2-1
,2v
,3h
,3v
,3s
.
Changes the current chart layout.
Returns the current layout name. If the current layout has not yet been saved then it returns undefined.