Widget Constructor - SpartaCommodities/Trading_view_wiki GitHub Wiki
You may specify Charting library widget parameters when calling its constructor. Here is an example of a call.
new TradingView.widget({
    symbol: 'A',
    interval: '1D',
    timezone: "America/New_York",
    container: "tv_chart_container",
    locale: "ru",
    datafeed: new Datafeeds.UDFCompatibleDatafeed("https://demo_feed.tradingview.com"),
    library_path: "charting_library/"
});Below is a complete list of supported parameters. Use Widget methods if you wish to modify the parameters after the creation of the Charting Library.
* - Required
- Library and Trading Terminal
- symbol, interval*
- container*
- datafeed*
- library_path*
- timeframe
- timezone
- debug
- width, height
- fullscreen
- autosize
- symbol_search_request_delay
- auto_save_delay
- toolbar_bg
- study_count_limit
- studies_access
- drawings_access
- saved_data
- saved_data_meta_info
- locale
- numeric_formatting
- custom_formatters
- overrides
- disabled_features, enabled_features
- snapshot_url
- custom_indicators_getter
- preset
- studies_overrides
- time_frames
- charts_storage_url, client_id, user_id
- charts_storage_api_version
- load_last_chart
- theme
- custom_css_url
- custom_font_family
- loading_screen
- favorites
- save_load_adapter
- settings_adapter
- compare_symbols
- additional_symbol_info_fields
- header_widget_buttons_mode
- time_scale
- custom_translate_function
- symbol_search_complete
- context_menu
- settings_overrides
 
- Trading Terminal only
The default symbol & time interval of your chart. The interval value is described in the Section.
symbol: 'A',
interval: '1D',The container can either be a reference to an attribute of a DOM element inside which the iframe with the chart will be placed or the HTMLElement itself.
container: "tv_chart_container",or
container: document.getElementById("tv_chart_container"),JavaScript object that implements the (JS API) interface to supply the chart with data.
datafeed: new Datafeeds.UDFCompatibleDatafeed("https://demo_feed.tradingview.com")Sets the default timeframe of the chart.
The timeframe can be relative to the current date, or a range.
A relative timeframe is a number with a letter D for days and M for months:
timeframe: '3M',A range is an object with to and from properties. The to and from properties should be UNIX timestamps:
timeframe: { from: 1640995200, to: 1643673600 } // from 2022-01-01 to 2022-02-01Note: When using a range the chart will still request data up to the current date. This is to enable scrolling foreward in time once the chart has loaded.
Default timezone of the chart. The time on the timescale is displayed according to this timezone.
See the list of supported timezones for available values. Set it to exchange to use the exchange timezone. Use the overrides section if you wish to override the default value.
timezone: "America/New_York",Setting this property to true will make the chart write detailed API logs into the browser console. Alternatively, you can use the charting_library_debug_mode featureset to enable it.
debug: true,A path to a static folder.
library_path: "charting_library/",- If you would like to host the library on a separate origin to the page containing the chart then please view the following guide: Hosting the library on a separate origin.
The desired size of a widget. Please make sure that there is enough space for the widget to be displayed correctly.
width: 300,
height: 600,Remark: If you want the chart to use all the available space use the fullscreen parameter instead of setting it to '100%'.
Default: false
Boolean value showing whether the chart should use all the available space in the window.
fullscreen: true,Default: false
Boolean value showing whether the chart should use all the available space in the container and resize when the container itself is resized.
autosize: true,A threshold delay in milliseconds that is used to reduce the number of symbol search requests when the user is typing a name of a symbol in the search box.
symbol_search_request_delay: 1000,A threshold delay in seconds that is used to reduce the number of onAutoSaveNeeded calls.
auto_save_delay: 5,Background color of the toolbars.
toolbar_bg: '#f4f7f9',Starting from version 1.5.
Maximum amount of studies on the chart of a multichart layout. Minimum value is 2.
study_count_limit: 5,Starting from version 1.1.
An object with the following structure:
studies_access: {
    type: "black" | "white",
    tools: [
        {
            name: "<study name>",
            grayed: true
        },
        < ... >
    ]
}- 
typeis the list type. Supported values are:black(all listed items should be disabled),white(only the listed items should be enabled).
- 
toolsis an array of objects. Each object could have the following properties:- 
name(Mandatory) is the name of a study. Use the same names as in the pop-ups of indicators.
- 
grayedis a boolean showing whether this study should be visible but look as if it's disabled. If the study is grayed out and user clicks it, then theonGrayedObjectClickedfunction is called.
 
- 
Starting from version 1.1.
This property has the same structure as the studies_accessargument that is described above. Use the same names as you see in the UI.
drawings_access: {
    type: 'black',
    tools: [
        {
            name: 'Trend Line',
            grayed: true
        },
    ]
},Remark: There is a special case for font-based drawings. Use the "Font Icons" name for them. Those drawings cannot be enabled or disabled separately - the entire group will have to be either enabled or disabled.
JS object containing saved chart content. Use this parameter when creating the widget if you have a saved chart already. If you want to load the chart content when the chart is initialized then use load() method of the widget.
JS object containing saved chart content meta info. This object should have the following fields:
- 
uid: unique integer identifier of the chart
- 
name: saved chart name
- 
description: saved chart description
Locale to be used by Charting Library. See Localization section for details.
locale: 'en',The object containing formatting options for numbers. The only possible option is decimal_sign currently.
numeric_formatting: { decimal_sign: "," },It is an object that contains the following fields:
- timeFormatter
- dateFormatter
- tickMarkFormatter
- priceFormatterFactory
- studyFormatterFactory
You can use these formatters to adjust the display format of the date and time values.
timeFormatter and dateFormatter are objects that include functions such as format and formatLocal:
function format(date)
function formatLocal(date)These functions should return the text that specifies date or time. formatLocal should convert date and time to local timezone.
tickMarkFormatter is a function with the following signature:
function tickMarkFormatter(date: Date, tickMarkType: TickMarkType): string;
/**
 * Represents the type of a tick mark on the time axis.
 */
type TickMarkType =
    /**
     * The start of the year (e.g. it's the first tick mark in a year).
     */
    | 'Year'
    /**
     * The start of the month (e.g. it's the first tick mark in a month).
     */
    | 'Month'
    /**
     * A day of the month.
     */
    | 'DayOfMonth'
    /**
     * A time without seconds.
     */
    | 'Time'
    /**
     * A time with seconds.
     */
    | 'TimeWithSeconds';priceFormatterFactory is a function with the following signature:
function priceFormatterFactory(symbolInfo: ISymbolInfo | null, minTick: string): ISymbolValueFormatter;
interface ISymbolValueFormatter {
    format(price: number, signPositive?: boolean): string;
}studyFormatterFactory is a function with the following signature:
function studyFormatterFactory(format: CustomStudyFormatterFormat, symbolInfo: ISymbolInfo | null): CustomStudyFormatter;
interface CustomStudyFormatter {
    format(value: number): string;
}
export interface CustomStudyFormatterFormat {
    type: 'price' | 'volume' | 'percent';
    precision: number | undefined;
}Example:
custom_formatters: {
    timeFormatter: {
        format: (date) => {
            const _format_str = '%h:%m';
            return _format_str
                .replace('%h', date.getUTCHours(), 2)
                .replace('%m', date.getUTCMinutes(), 2)
                .replace('%s', date.getUTCSeconds(), 2);
        }
    },
    dateFormatter: {
        format: (date) => {
            return date.getUTCFullYear() + '/' + (date.getUTCMonth() + 1) + '/' + date.getUTCDate();
        }
    },
    tickMarkFormatter: (date, tickMarkType) => {
        switch (tickMarkType) {
            case 'Year':
                return 'Y' + date.getUTCFullYear();
            case 'Month':
                return 'M' + (date.getUTCMonth() + 1);
            case 'DayOfMonth':
                return 'D' + date.getUTCDate();
            case 'Time':
                return 'T' + date.getUTCHours() + ':' + date.getUTCMinutes();
            case 'TimeWithSeconds':
                return 'S' + date.getUTCHours() + ':' + date.getUTCMinutes() + ':' + date.getUTCSeconds();
        }
        throw new Error('unhandled tick mark type ' + tickMarkType);
    },
    priceFormatterFactory: (symbolInfo, minTick) => {
        if (symbolInfo?.fractional || minTick !== 'default' && minTick.split(',')[2] === 'true') {
            return {
                format: (price, signPositive) => {
                    // return the appropriate format
                },
            };
        }
        return null; // this is to use default formatter;
    },
    studyFormatterFactory: (format, symbolInfo) => {
        if (format.type === 'price') {
            const numberFormat = new Intl.NumberFormat('en-US', { notation: 'scientific' });
            return {
                format: (value) => numberFormat.format(value)
            };
        }
        if (format.type === 'volume') {
            return {
                format: (value) => (value / 1e9).toPrecision(format?.precision || 2) + 'B'
            };
        }
        if (format.type === 'percent') {
            return {
                format: (value) => `${value.toPrecision(format?.precision || 4)} percent`
            };
        }
        return null; // this is to use default formatter;
    },
}Remark: tickMarkFormatter must display the UTC date, and not the date corresponding to your local timezone.
The object that contains new values for default widget properties.
You can override most of the Charting Library properties (which also may be edited by user through UI) using overrides parameter of Widget constructor. overrides is supposed to be an object. The keys of this object are the names of overridden properties. The values of these keys are the new values of the properties. Example:
overrides: {
    "mainSeriesProperties.style": 2
}This code will change the default series style to "line". All customizable properties are listed in separate article. You can use Drawings-Overrides starting from v 1.5.
The array containing names of features that should be enabled/disabled by default. Feature means part of the functionality of the chart (part of the UI/UX). Supported features are listed here.
Example:
disabled_features: ["header_widget", "left_toolbar"],
enabled_features: ["move_logo_to_main_pane"],This URL is used to send a POST request with binary chart snapshots when a user presses the snapshot button.
This POST request contains multipart/form-data with the field preparedImage that represents binary data of the snapshot image in image/png format.
This endpoint should return the full URL of the saved image in the the response.
snapshot_url: "https://myserver.com/snapshot",Function that returns a Promise object with an array of your custom indicators.
PineJS variable will be passed as the first argument of this function and can be used inside your indicators to access internal helper functions. This PineJS helper library is described in more detail here.
See more details here.
custom_indicators_getter: function(PineJS) {
    return Promise.resolve([
        // *** your indicator object, created from the template ***
    ]);
},preset is a name of predefined widget settings. For now, the only value supported in the preset is  mobile. The example of this preset is available here.
preset: "mobile",Use this option to customize the style or inputs of the indicators. You can also customize the styles and inputs of the Compare series using this argument. See more details here
studies_overrides: {
    "volume.volume.color.0": "#00FFFF",
},List of visible timeframes that can be selected at the bottom of the chart. See this topic to learn more about timeframes. Timeframe is an object containing following properties:
- 
text- a string with the following format:<integer><y|m|d>( \d+(y|m|d) as Regex ). It defines the range to be set.
- 
resolution- a string with the format described here. It defines the resolution to be set.
- 
description(optional) - a string that is displayed in the pop-up menu. If it isn't set then thetitleproperty is used.
- 
title(optional) - a string representation of the time frame. If it is not set then the title is generated based on thetextproperty.
Example:
time_frames: [
    { text: "50y", resolution: "6M", description: "50 Years" },
    { text: "3y", resolution: "1W", description: "3 Years", title: "3yr" },
    { text: "8m", resolution: "1D", description: "8 Month" },
    { text: "3d", resolution: "5", description: "3 Days" },
    { text: "1000y", resolution: "1W", description: "All", title: "All" },
]These arguments are related to the high-level API for saving/loading the charts. See more details here.
charts_storage_url: 'http://storage.yourserver.com',
client_id: 'yourserver.com',
user_id: 'public_user_id',A version of your backend. Supported values are: "1.0" | "1.1". Study Templates are supported starting from version "1.1".
charts_storage_api_version: "1.1",Set this parameter to true if you want the library to load the last saved chart for a user (you should implement save/load first to make it work).
load_last_chart: true,Starting from version 1.13.
Adds custom theme color for the chart. Supported values are: "Light" | "Dark".
theme: "Light",Starting from version 1.4.
Adds your custom CSS to the chart. url should be an absolute or relative path to the static folder.
custom_css_url: 'css/style.css',See loading_screen for adjusting the loading spinner colors.
Change the font family used on the chart. The value should be in the same format as the font-family property in CSS.
If you want to use a font that is not available by default on your system, you need to first load the font in your custom CSS.
E.g. importing a google font in your custom CSS:
@import url('https://fonts.googleapis.com/css2?family=Inconsolata:wght@500&display=swap');Add custom_font_family to your widget options:
custom_font_family: "'Inconsolata', monospace",Starting from version 1.12.
Customization of the loading spinner. Value is an object with the following possible keys:
- backgroundColor
- foregroundColor
Example:
loading_screen: { backgroundColor: "#000000" }Items that should be marked as favorite by default. This option requires that the usage of localstorage is disabled (see featuresets to know more). The favorites property is supposed to be an object. The following properties are supported:
- 
intervals: an array of time intervals that are marked as favorite. Example: ["D", "2D"]
- 
chartTypes: an array of chart types that are marked as favorite. The names of chart types are identical to chart's UI in the English version. Example: ["Area", "Candles"].
favorites: {
    intervals: ["1D", "3D", "3W", "W", "M"],
    chartTypes: ["Area", "Line"]
},An object containing the save/load functions. It is used to implement a custom save/load algorithm. Please see details and an example on Saving and Loading Charts page.
Starting from version 1.11.
An object that contains set/remove functions. Use it to save chart settings to your preferred storage (including server-side). If it is available then it should have the following methods:
- 
initialSettings: ObjectAn object with the initial settings 
- 
setValue(key: string, value: string): voidA function that is called to store key/value pair. 
- 
removeValue(key: string): voidA function that is called to remove a key. 
settings_adapter: {
    initialSettings: { ... },
    setValue: function(key, value) { ... },
    removeValue: function(key) { ... },
}Starting from version 17.
An optional field containing an array of custom compare symbols for the Compare window. Each symbol info should contain the following fields:
- 
symbol- a string that defines a symbol to compare
- 
title- a string, the name of instrument that will be displayed near the corresponding checkbox
compare_symbols: [
    { symbol: 'DAL', title: 'Delta Air Lines' },
    { symbol: 'VZ', title: 'Verizon' },
    ...
];An optional field containing an array of custom symbol info fields to be shown in the Symbol Info dialog. Each additional symbol info field should have the following properties:
- 
title- a string that is used as the name of the new symbol info
- 
propertyName- a string that is used to look up a property from the symbol info returned from the chart's datafeed
See Symbology for more information about symbol info.
additional_symbol_info_fields: [
    { title: 'Ticker', propertyName: 'ticker' }
]An additional optional field to change the look and feel of buttons on the top toolbar. Mode can be of the following:
- 
fullsize: always full-size buttons on the top toolbar
- 
adaptive: adaptive/auto mode (fullsize if the window width allows and icons on small windows).
- 
compact: icons only buttons on the top toolbar (favorites won't be shown)
By default (if option is omitted) header will be in adaptive mode (fullsize if the window width allows and icons on smaller windows).
header_widget_buttons_mode: 'fullsize',An additional optional field to add more bars on screen. At the moment the only sub-option available are:
- 
min_bar_spacing: number - should be greater than 0.
time_scale: {
    min_bar_spacing: 10,
}Use this property to set your own translation function. key and options will be passed to the function.
You can use this function to provide custom translations for some strings.
The function should return either a string with a new translation or null to fallback to the default translation.
For example, if you want to rename "Trend Line" shape to "Line Shape", then you can do something like this:
custom_translate_function: (key, options) => {
    if (key === 'Trend Line') {
        // patch the title of trend line
        return 'Line Shape';
    }
    return null;
}Use this property to set a function to override the symbol input from symbol search dialogs.
For example for you may want to get additional input from the user before deciding which symbol should be resolved.
The function should take one parameter: a string of input from the symbol search and should return a Promise that resolves with the new symbol string.
NOTE: This override is not called when adding a symbol to the watchlist.
symbol_search_complete: (symbol) => {
    return new Promise((resolve) => {
        let newSymbol = getNewSymbol(symbol);
        resolve(newSymbol);
    });
}You could use this object to override context menu in some way.
Provide this function if you want to change the set of actions being displayed in the context menu.
You can filter out, add yours and re-order items.
The library will call your function each time it wants to display a context menu and with provide a list of items to display. This function should return an array of items to display.
A function has the following signature:
type ContextMenuItemsProcessor = (items: readonly IActionVariant[], actionsFactory: ActionsFactory) => Promise<readonly IActionVariant[]>;Where:
- 
items- an array of items the library wants to display
- 
actionsFactory- a factory you could use to create a new items for the context menu. It consists of the following methods:- 
createAction- creates an action with provided options.
- 
createAsyncAction- creates an action that will wait for a promise to get its options. In terms of GUI until a promise is resolved the loader/spinner will be displayed.
- 
createSeparator- creates a separator item.
 
- 
Your function must return a Promise for an array of context menu items to display. Please look at TypeScript declaration file provided with the package for types and possible options/functions you might use.
EXPERIMENTAL.
By providing this function you could override the default renderer for context menu. The signature of the function is the following:
export type ContextMenuRendererFactory = (items: readonly IActionVariant[], params: CreateContextMenuParams, onDestroy: () => void) => Promise<IContextMenuRenderer>;Where:
- 
items- an array of items the library wants to display
- 
params- an object representing where the user right-clicked on (only if there is an existing menu), consisting of:- 
menuName- name of the menu
- 
detail- object providing more details for the menu:- 
type- could be eitherseries|study,shapeorgroupOfShapes
- 
id- string (series), string | null (study), number | string | null (shape) or string | null (groupOfShapes)
 
- 
 
- 
- 
onDestroy- a function that you should call once a created menu is hidden/destroyed
The returned value should be a Promise object that resolves with an object with the following methods:
- 
show(pos)- displays the menu at the positionpos. Please refer to TypeScript declaration file for exact type ofpositionobject.
- 
hide()- hides the menu.
- 
isShown()- returns whether a menu is currently displayed.
The object that contains new values for values saved to the settings. These overrides will replace any matching values from the settings, regardless of where the settings are loaded from (i.e. local storage or a custom settings adapter). The object is similar to the overrides object.
overrides will not affect values that have been saved to settings so this option can be used instead.
settings_overrides: {
    "linetooltrendline.linecolor": "blue"
}💹 applies to Trading Terminal only
The object that contains settings for the widget panel on the right side of the chart. Watchlist, news, details and data window widgets on the right side of the chart can be enabled using the widgetbar field in Widget constructor:
widgetbar: {
    details: true,
    watchlist: true,
    news: true,
    datawindow: true,
    watchlist_settings: {
        default_symbols: ["NYSE:AA", "NYSE:AAL", "NASDAQ:AAPL"],
        readonly: false
    },
}- 
details(default:false): Enables details widget in the widget panel on the right.
- 
watchlist(default:false): Enables watchlist widget in the widget panel on the right.
- 
news(default:false): Enables news widget in the widget panel on the right.
- 
datawindow(default:false): Enables data window widget in the widget panel on the right.
- 
watchlist_settings.default_symbols(default:[]): Sets the list of default symbols for watchlist.
- 
watchlist_settings.readonly(default:false): Enables read-only mode for the watchlist.
💹 applies to Trading Terminal only
Use this property to change the RSS feed for news. You can set a different RSS for each symbol type or use a single RSS for all symbols. The object should have the default property, other properties are optional. The names of the properties match the symbol types. Each property is an object (or an array of objects) with the following properties:
- 
url- is a URL to be requested. It can contain tags in curly brackets that will be replaced by the terminal:{SYMBOL},{TYPE},{EXCHANGE}.
- 
name- is a name of the feed to be displayed underneath the news.
Here is an example:
rss_news_feed: {
    default: [ {
        url: "https://articlefeeds.nasdaq.com/nasdaq/symbols?symbol={SYMBOL}",
        name: "NASDAQ"
      }, {
        url: "http://feeds.finance.yahoo.com/rss/2.0/headline?s={SYMBOL}®ion=US&lang=en-US",
        name: "Yahoo Finance"
      } ]
},Another example:
rss_news_feed: {
    "default": {
        url: "https://articlefeeds.nasdaq.com/nasdaq/symbols?symbol={SYMBOL}",
        name: "NASDAQ"
    }
}One more example:
rss_news_feed: {
    "default": {
        url: "https://articlefeeds.nasdaq.com/nasdaq/symbols?symbol={SYMBOL}",
        name: "NASDAQ"
     },
    "stock": {
        url: "http://feeds.finance.yahoo.com/rss/2.0/headline?s={SYMBOL}®ion=US&lang=en-US",
        name: "Yahoo Finance"
    }
}💹 applies to Trading Terminal only
Use this property to set your own news getter function. Both the symbol and callback will be passed to the function.
The callback function should be called with an object. The object should have two properties: title which is a optional string, and newsItems which is an array of news objects that have the following structure:
- 
title(required) - the title of news item.
- 
published(required) - the time of news item in ms (UTC).
- 
source(optional) - source of the news item title.
- 
shortDescription(optional) - Short description of a news item that will be displayed under the title.
- 
link(optional) - URL to the news story.
- 
fullDescription(optional) - full description (body) of a news item.
NOTE: Only title and published are the main properties used to compare what has already been published and what's new.
NOTE 2: When a user clicks on a news item a new tab with the link URL will be opened. If link is not specified then a pop-up dialog with fullDescription will be shown.
NOTE 3: If both news_provider and rss_news_feed are available then the rss_news_feed will be ignored.
See News API examples for usage examples.
💹 applies to Trading Terminal only
Use this field to pass the function that returns a new object which implements Broker API. This is a function that accepts Trading Host and returns Broker API.
broker_factory: function(host) { ... }💹 applies to Trading Terminal only
Use this field to set the configuration flags for the Trading Terminal. Read more.
broker_config: {
    supportReversePosition: true,
    supportPLUpdate: true,
    ...
},