Skip to main content

Save user settings

Overview

User settings are settings that remain regardless of the applied chart layout. They are stored separately from chart layouts to ensure that users have control over their specific preferences. For example, the Instant orders placement setting in Trading Platform allows users to place orders without confirmation. This setting is a part of user settings and is not saved when users save the chart layouts. Saving this setting within a chart layout could lead to unexpected user experiences and is considered a bad practice.

Settings list

User settings include:

  • Resolution
  • Order type and quantity in the Order Ticket
  • Chart settings → Trading
    • Buy/Sell buttons
    • Instant orders placement
    • Play sound for executions
    • Notifications
  • Summary row in the Account Manager
  • Right and bottom widget bars view
  • Chart style
  • Watchlist

How to store

There are two options for storing user settings:

Settings adapter

You can save user settings using the settings_adapter property of the Widget Constructor. This property allows not only storing settings in the preferred storage but also applying them to the chart.

info

The library provides multiple approaches to modify the chart's appearance and behavior, and settings_adapter is one of them. These approaches have a specific application order, meaning they may override any styles or settings applied by other approaches lower on the list. Refer to Customization precedence for more information.

The settings_adapter property accepts the ISettingsAdapter object. In the initialSettings property of ISettingsAdapter, specify the settings the chart should be initiated with. You should also implement two methods setValue and removeValue, which are triggered upon changes in settings.

Consider the code sample below that does the following:

  • Sets a watermark on the chart when the chart is initialized.
  • Sets settings (10 units of shares and the limit order type) for the Order Ticket when the chart is initialized.
  • Logs actions in the console when settings are set or removed.
new TradingView.widget({
/* Other properties */

settings_adapter: {
initialSettings: {
"symbolWatermark": '{ "visibility": "true", "color": "rgba(244, 67, 54, 0.25)" }',
"trading.Broker": '{"qty": {"AAPL": 10, "NasdaqNM:AAPL": 10}, "orderType": {"NasdaqNM:AAPL": 3}}',
},
setValue: function (key, value) {
console.log(`set value: ${key} ${value}`);
},
removeValue: function (key) {
console.log(`remove value: ${key}`);
},
}
})