StyleLibraryLibrary   "StyleLibrary" 
A small library of Pine Script functions that return built-in style variables.
 method sizeStyle(size) 
  Takes a `string` that returns the corresponding built-in size style variable.
  Namespace types: series string, simple string, input string, const string
  Parameters:
     size (string) : A `string` representing a built-in size style: `"Tiny"`, `"Small"`, `"Normal"`, `"Large"`,
`"Huge"`, `"Auto"`.
  Returns: The respective built-in size style variable.
 method sizeStyle(size) 
  Takes a `sizeStyle` that returns the corresponding built-in size style variable.
  Namespace types: series sizeStyle
  Parameters:
     size (series sizeStyle) : A `sizeStyle` representing a built-in size style variable.
  Returns: The respective built-in size style variable.
 method lineStyle(style) 
  Takes a `string` that returns the corresponding built-in line style variable.
  Namespace types: series string, simple string, input string, const string
  Parameters:
     style (string) : A `string` representing a built-in line style: `"Dashed"`, `"Dotted"`, `"Solid"`.
  Returns: The respective built-in line style variable.
 method lineStyle(style) 
  Takes a `lineStyle` that returns the corresponding built-in line style variable.
  Namespace types: series lineStyle
  Parameters:
     style (series lineStyle) : A `lineStyle` representing a built-in line style variable.
  Returns: The respective built-in line style variable.
 method labelStyle(style) 
  Takes a `string` that returns the corresponding built-in label style variable.
  Namespace types: series string, simple string, input string, const string
  Parameters:
     style (string) : A `string` representing a built-in label style:
`"Arrow Down"`, `"Arrow Up"`, `"Circle"`, `"Cross"`, `"Diamond"`, `"Flag"`,
`"Label Center"`, `"Label Down"`, `"Label Left"`, `"Label Lower Left"`,
`"Label Lower Right"`, `"Label Right"`, `"Label Up"`, `"Label Upper Left"`,
`"Label Upper Right"`, `"None"`, `"Square"`, `"Text Outline"`, `"Triangle Down"`,
`"Triangle Up"`, `"XCross"`.
  Returns: The respective built-in label style variable.
 method labelStyle(style) 
  Takes a `labelStyle` that returns the corresponding built-in label style variable.
  Namespace types: series labelStyle
  Parameters:
     style (series labelStyle) : A `labelStyle` representing a built-in label style variable.
  Returns: The respective built-in label style variable.
 method fontStyle(font) 
  Takes a `string` that returns the corresponding built-in font style variable.
  Namespace types: series string, simple string, input string, const string
  Parameters:
     font (string) : A `string` representing a built-in font style: `"Default"`, `"Monospace"`.
  Returns: The respective built-in font style variable.
 method positionStyle(position) 
  Takes a `string` that returns the corresponding built-in position style variable.
  Namespace types: series string, simple string, input string, const string
  Parameters:
     position (string) : A `string` representing a built-in position style:
`"Bottom Center", `"Bottom Left", `"Bottom Right", `"Middle Center", `"Middle Left",
`"Middle Right", `"Top Center", `"Top Left", `"Top Right".
  Returns: The respective built-in position style variable.
 method displayStyle(display) 
  Takes a `simple string` that returns the corresponding built-in display style variable.
  Namespace types: simple string, input string, const string
  Parameters:
     display (simple string) : A `simple string` representing a built-in display style: `"All"`, `"Data Window"`,
`"None"`, `"Pane"`, `"Price Scale"`, `"Status Line"`.
  Returns: The respective built-in display style variable.
Table
4C Data Table SuiteOverview 
The 4C Data Table Suite is a versatile TradingView indicator, designed for traders who focus on the critical role of prior bar levels in their strategy. By highlighting the high and low points of previous bars, this tool aids in pinpointing crucial support and resistance zones, which often act as psychological triggers for market participants. The unique feature of this indicator is its dual-color coding: it colors bars green for bullish closes and red for bearish closes in the Prior Bar Table, and for the current timeframe, it highlights whether the current price is above (green) or below (red) these levels.
 Concepts 
1 — This sophisticated indicator is not just about visual cues; it provides a rich tableau of data including:
  • Current timeframe countdown to bar close
  • GMT-adjusted clock for precise trade timing
  • Real-time updates on market internals and volatility measures such as the NYSE TICK and ATR
2 — The configuration is highly customizable, allowing users to:
  • Adjust the table's positioning and text size
  • Choose color settings for text, background, and borders to suit their visual preference
  • Toggle the display of various data components based on their trading needs
3 — The Prior Bar Table is particularly valuable for:
  • Traders using prior bar levels as triggers for trade entries and exits
  • Quick visual assessment of market sentiment
  • Real-time decision-making supported by dynamic color coding based on current price movements relative to prior highs and lows
 Features 
• Prior Bar Levels Table: Visualizes high and low levels of prior bars with intuitive color coding, aiding traders in assessing market trends.
• Dynamic Color Coding: Updates colors based on the closure of the previous bar and current price positions relative to the past bar's highs and lows.
• Comprehensive Market Data: Includes a suite of essential data such as market internals, the prior bar’s range, and the latest price information.
• Customizable Visuals: Offers extensive options for customizing the appearance and data presented, ensuring the tool fits seamlessly into any trader's strategy.
 How to Use
 1. To add the indicator, search for "4C Data Table Suite" under indicators on TradingView and apply it to your chart.
2. Navigate to the indicator settings to customize the display properties, including table position, color schemes, and which data points to display.
3. Utilize the toggles within the "Prior Bar Levels Table" settings to adjust the visibility and behavior of the table, depending on your trading approach.
 Limitations 
• This indicator is optimized for use on time-based charts and may not perform as intended on tick charts or non-standard timeframes.
• The color coding is based on the closure of bars, which may not always reflect intrabar movements, potentially affecting real-time decision-making in highly volatile markets.
 Notes 
• Ensure your TradingView interface is set to the correct timezone settings to align the GMT clock accurately.
• The dynamic color updates are designed to provide at-a-glance insights but should be used in conjunction with other analysis tools for best results.
*If you find that the indicator is blocking some of the candles at the bottom of the screen, go to (Chart) Settings, Canvas, and then adjust the Bottom/Top margin by increasing the % Amount.
 Thanks 
Special thanks to the TradingView community and developers whose feedback and insights have helped refine the functionalities of the 4C Data Table Suite. Your collaborative spirit is what makes continuous improvement possible.
Volatility DashboardThis indicator calculates and displays volatility metrics for a specified number of bars (rolling window) on a TradingView chart. It can be customized to display information in English or Thai and can position the dashboard at various locations on the chart.
 Inputs 
 
  Language: Users can choose between English ("ENG") and Thai ("TH") for the dashboard's language.
  Dashboard Position: Users can specify where the dashboard should appear on the chart. Options include various positions such as "Bottom Right", "Top Center", etc.
  Calculation Method: Currently, the script supports "High-Low" for volatility calculation. This method calculates the difference between the highest and lowest prices within a specified timeframe.
  Bars: Number of bars used to calculate the volatility.
 
 Display Logic 
 
  Fills the islast_vol_points array with the calculated volatility points.
  Sets the table cells with headers and corresponding values: 
     => Highest Volatility: The maximum value in the islast_vol_points array
     => Mean Volatility: The average value in the islast_vol_points array, 
     => Lowest Volatility: The minimum value in the islast_vol_points array, Number of Bars: The rolling window size.
 
DeleteArrayType█ OVERVIEW
Here are common functions usually delete drawing once array of drawing is recall.
Method is used as in pine script version 5 instead of custom function.
It is an upgrade from  DeleteArrayObject , which may not support overload parameter in future.
Library   "DeleteArrayType" 
TODO: Delete array type especially for drawings
 method deleteLabel(id) 
  TODO: Delete array
  Namespace types: array
  Parameters:
     id (array) 
  Returns: TODO: label.delete()
 method deleteLine(id) 
  TODO: Delete array
  Namespace types: array
  Parameters:
     id (array) 
  Returns: TODO: line.delete()
 method deleteLineFill(id) 
  TODO: Delete array
  Namespace types: array
  Parameters:
     id (array) 
  Returns: TODO: linefill.delete()
 method deletePolyLine(id) 
  TODO: Delete array
  Namespace types: array
  Parameters:
     id (array) 
  Returns: TODO: polyline.delete()
 method deleteBox(id) 
  TODO: Delete array
  Namespace types: array
  Parameters:
     id (array) 
  Returns: TODO: box.delete()
 method deleteTable(id) 
  TODO: Delete array
  Namespace types: array
  Parameters:
     id (array) 
  Returns: TODO: table.delete()
MTF TREND-PANEL-(AS) 
0). INTRODUCTION: "MTF TREND-PANEL-(AS)" is a technical tool for traders who often perform multi-timeframe analysis.
This simple tool is meant for traders who wish to monitor and keep track of trend directions simultaneously on various timeframes, ranging from 1MIN to 3MONTHS (or other - 'DIFF')
script enhances decision-making efficiency and provides a clearer picture of market condition by integrating multiple timeframe analysis into a single panel.
1). WARNING!:
-script doesn't make any calculations on its own really but is more of a tool for traders to remember what is happening on other time frames
- use tooltips to navigate settings easier
2). MAIN OPTIONS:
- Keeps track of up to 7 timeframes. (NUMBER of TimeFrames setting, from 1-7)
- Customizable Display: Choose to display nothing, upward/downward arrows, or a range indication for each timeframe.
- timeframe options: '1-MIN','5-MIN','15-MIN','30-MIN','1H','4H','1D','1W','1M','3M','DIFF'
- Color Coding: Define your preferred colors for each timeframe
- set position of the table and size of text (Position/text)
- Personal Touch: Add your own trading maxim or motto for inspiration to show up when SHOW TEXT is turned on
3. )OPTIONS:
-NUMBER of TimeFrames setting: from 1-7 - how many rows to show
-SHOW TABLE: Toggle to display or hide the trend table panel.
-SHOW TEXT: Show or hide your personalized trading maxim.
-SHOW TREND: Enable to display trend direction arrows.
-SHOW_CLRS: Turn on to activate color coding for each timeframe.
-position/text size for table
-settings for each timeframe:color,time,trend
-place to type ur own text
5). How to Use the Script:
-After adding the script to your chart, use the 'NUMBER of TimeFrames' setting to select how many timeframes you want to track (1 to 7).
-Customize the appearance of each timeframe row using the color and arrow options.
-For trend analysis, the script offers arrows to indicate upward, downward, or ranging markets.
-decide what trend dominates particular TF (using other tools  - script does not calculate trend on its own )
- mark trends on panel to keep track of all TF
-Enable or disable various features like the table panel, trader maxim, and color coding using the ON/OFF options.
6). just in case:
- ask me anything about the code
-don't be shy to report any bugs or offer improvements of any kind.
- originally created for @ict_whiz and made public at his request
MUJBOT - Multi-TF RSI Table
The "Multi-TF RSI Table" indicator is a comprehensive tool designed to present traders with a quick visual summary of the Relative Strength Index (RSI) across multiple timeframes, all within a single glance. It is crafted for traders who incorporate multi-timeframe analysis into their trading strategy, aiming to enhance decision-making by identifying overall market sentiment and trend direction. Here's a rundown of its features:
User Inputs: The indicator includes customizable inputs for the RSI and Moving Average (MA) lengths, allowing users to tailor the calculations to their specific trading needs. Additionally, there is an option to display or hide the RSI & MA table as well as to position it in various places on the chart for optimal visibility.
Multi-Timeframe RSI & MA Calculations: It fetches RSI and MA values from different timeframes, such as 1 minute (1m), 5 minutes (5m), 15 minutes (15m), 1 hour (1h), 4 hours (4h), and 1 day (1D). This multi-timeframe approach provides a thorough perspective of the momentum and trend across different market phases.
Trend and Sentiment Analysis: For each timeframe, the script determines whether the average RSI is above or below the MA, categorizing the trend as "Rising", "Falling", or "Neutral". Moreover, it infers market sentiment as "Bullish" or "Bearish", based on the relationship between the RSI and its MA.
Dynamic Color-Coding: The indicator uses color-coding to convey information quickly. It highlights the trend and sentiment cells in the table with green for "Bullish" and red for "Bearish" conditions. It also shades the timeframe cells based on the RSI value, with varying intensities of green for "Oversold" conditions and red for "Overbought" conditions, providing an immediate visual cue of extreme market conditions.
Customization and Adaptability: The script is designed with customization in mind, enabling users to adjust the RSI and MA lengths according to their trading strategy. Its adaptable interface, which offers the option to display or hide the RSI & MA table, ensures that the tool fits into different trading setups without cluttering the chart.
Ease of Use: By consolidating critical information into a simple table, the "Multi-TF RSI Table" indicator saves time and simplifies the analysis process for traders. It eliminates the need to switch between multiple charts or timeframes, thus streamlining the trading workflow.
In essence, the "Multi-TF RSI Table" is a powerful indicator for Pine Script users on TradingView, offering a multi-dimensional view of market dynamics. It is ideal for both novice and experienced traders who seek to enhance their technical analysis with an at-a-glance summary of RSI trends and market sentiment across various timeframes.
Table to filter trades per dayThis script contains a block of code that allows users to filter the total number of trades, loss trades, win trades and win rate per day in a table. This makes it easier to compare which days were profitable and which were not. 
Be aware that this script can only be used in strategy scripts. To use the script, open it and copy every line from "START" to "STOP". Then, paste these lines at the very bottom of the strategy script that you want to attach it to.
The user has the ability to adjust the position of the table and customize the size of the text displayed.
If the user sets "Check when the trade:" to "Opened", the script will monitor when the trade opens and add it to the table once it has been closed. If "Check when the trade:" is set to "Closed", the script will track when the trade is closed and add it to the table once it has been closed.
It is recommended to run the script on the "Exchange" setting for more accurate results, even though a "Set the timezone" option is available. This will prevent discrepancies caused by daylight saving time changes.
Please note that the code will only work properly if you choose a daily timeframe or lower.
Adaptive MFT Extremum Pivots [Elysian_Mind]Adaptive MFT Extremum Pivots 
 Overview: 
The Adaptive MFT Extremum Pivots indicator, developed by Elysian_Mind, is a powerful Pine Script tool that dynamically displays key market levels, including Monthly Highs/Lows, Weekly Extremums, Pivot Points, and dynamic Resistances/Supports. The term "dynamic" emphasizes the adaptive nature of the calculated levels, ensuring they reflect real-time market conditions. I thank Zandalin for the excellent table design. 
---
 Chart Explanation: 
The table, a visual output of the script, is conveniently positioned in the bottom right corner of the screen, showcasing the indicator's dynamic results. The configuration block, elucidated in the documentation, empowers users to customize the display position. The default placement is at the bottom right, exemplified in the accompanying chart.
The deliberate design ensures that the table does not obscure the candlesticks, with traders commonly situating it outside the candle area. However, the flexibility exists to overlay the table onto the candles. Thanks to transparent cells, the underlying chart remains visible even with the table displayed atop.
In the initial column of the table, users will find labels for the monthly high and low, accompanied by their respective numerical values. The default precision for these values is set at #.###, yet this can be adjusted within the configuration block to suit markets with varying degrees of volatility.
Mirroring this layout, the last column of the table presents the weekly high and low data. This arrangement is part of the upper half of the table. Transitioning to the lower half, users encounter the resistance levels in the first column and the support levels in the last column.
At the center of the table, prominently displayed, is the monthly pivot point. For a comprehensive understanding of the calculations governing these values, users can refer to the documentation. Importantly, users retain the freedom to modify these mathematical calculations, with the table seamlessly updating to reflect any adjustments made.
Noteworthy is the table's persistence; it continues to display reliably even if users choose to customize the mathematical calculations, providing a consistent and adaptable tool for informed decision-making in trading.
This detailed breakdown offers traders a clear guide to interpreting the information presented by the table, ensuring optimal use and understanding of the Adaptive MFT Extremum Pivots indicator.
---
 Usage: 
 Table Layout: 
The table is a crucial component of this indicator, providing a structured representation of various market levels. Color-coded cells enhance readability, with blue indicating key levels and a semi-transparent background to maintain chart visibility.
 1. Utilizing a Table for Enhanced Visibility: 
In presenting this wealth of information, the indicator employs a table format beneath the chart. The use of a table is deliberate and offers several advantages:
 2. Structured Organization: 
The table organizes the diverse data into a structured format, enhancing clarity and making it easier for traders to locate specific information.
 3. Concise Presentation: 
A table allows for the concise presentation of multiple data points without cluttering the main chart. Traders can quickly reference key levels without distraction.
 4. Dynamic Visibility: 
As the market dynamically evolves, the table seamlessly updates in real-time, ensuring that the most relevant information is readily visible without obstructing the candlestick chart.
 5. Color Coding for Readability: 
Color-coded cells in the table not only add visual appeal but also serve a functional purpose by improving readability. Key levels are easily distinguishable, contributing to efficient analysis.
 Data Values: 
Numerical values for each level are displayed in their respective cells, with precision defined by the iPrecision configuration parameter.
 Configuration: 
 // User configuration: You can modify this part without code understanding
// Table location configuration
// Position: Table
const string iPosition = position.bottom_right
// Width: Table borders
const int iBorderWidth = 1
// Color configuration
// Color: Borders
const color iBorderColor = color.new(color.white, 75)
// Color: Table background
const color iTableColor = color.new(#2B2A29, 25)
// Color: Title cell background
const color iTitleCellColor = color.new(#171F54, 0)
// Color: Characters
const color iCharColor = color.white
// Color: Data cell background
const color iDataCellColor = color.new(#25456E, 0)
// Precision: Numerical data
const int iPrecision = 3
// End of configuration 
The code includes a configuration block where users can customize the following parameters:
Precision of Numerical Table Data (iPrecision):
 // Precision: Numerical data
const int iPrecision = 3 
This parameter (iPrecision) sets the precision of the numerical values displayed in the table. The default value is 3, displaying numbers in #.### format.
Position of the Table (iPosition):
 // Position: Table
const string iPosition = position.bottom_right 
This parameter (iPosition) sets the position of the table on the chart. The default is position.bottom_right.
Color preferences
Table borders (iBorderColor):
 // Color: Borders
const color iBorderColor = color.new(color.white, 75) 
This parameters (iBorderColor) sets the color of the borders everywhere within the window.
Table Background (iTableColor):
 // Color: Table background
const color iTableColor = color.new(#2B2A29, 25) 
This is the background color of the table. If you've got cells without custom background color, this color will be their background.
Title Cell Background  (iTitleCellColor):
 // Color: Title cell background
const color iTitleCellColor = color.new(#171F54, 0) 
This is the background color the title cells. You can set the background of data cells and text color elsewhere.
Text (iCharColor):
 // Color: Characters
const color iCharColor = color.white 
This is the color of the text - titles and data - within the table window. If you change any of the background colors, you might want to change this parameter to ensure visibility.
Data Cell Background: (iDataCellColor):
 // Color: Data cell background
const color iDataCellColor = color.new(#25456E, 0) 
The data cells have a background color to differ from title cells. You can configure this is a different parameter (iDataColor). You might even set the same color for data as for the titles if you will.
---
 Mathematical Background: 
 Monthly and Weekly Extremums: 
The indicator calculates the High (H) and Low (L) of the previous month and week, ensuring accurate representation of these key levels.
 Standard Monthly Pivot Point: 
The standard pivot point is determined based on the previous month's data using the formula:
PivotPoint = (PrevMonthHigh + PrevMonthLow + Close ) / 3
 Monthly Pivot Points (R1, R2, R3, S1, S2, S3): 
Additional pivot points are calculated for Resistances (R) and Supports (S) using the monthly data:
R1 = 2 * PivotPoint - PrevMonthLow
S1 = 2 * PivotPoint - PrevMonthHigh
R2 = PivotPoint + (PrevMonthHigh - PrevMonthLow)
S2 = PivotPoint - (PrevMonthHigh - PrevMonthLow)
R3 = PrevMonthHigh + 2 * (PivotPoint - PrevMonthLow)
S3 = PrevMonthLow - 2 * (PrevMonthHigh - PivotPoint)
---
 Code Explanation and Interpretation: 
The table displayed beneath the chart provides the following information:
 Monthly Extremums: 
(H) High of the previous month
(L) Low of the previous month
 // Function to get the high and low of the previous month
getPrevMonthHighLow() =>
    var float prevMonthHigh = na
    var float prevMonthLow = na
    monthChanged = month(time) != month(time )
    
    if (monthChanged)
        prevMonthHigh := high 
        prevMonthLow := low 
    
     
 Weekly Extremums: 
(H) High of the previous week
(L) Low of the previous week
 // Function to get the high and low of the previous week
getPrevWeekHighLow() =>
    var float prevWeekHigh = na
    var float prevWeekLow = na
    weekChanged = weekofyear(time) != weekofyear(time )
    
    if (weekChanged)
        prevWeekHigh := high 
        prevWeekLow := low 
    
     
 Monthly Pivots: 
Pivot: Standard pivot point based on the previous month's data
 // Function to calculate the standard pivot point based on the previous month's data
getStandardPivotPoint() =>
      = getPrevMonthHighLow()
    pivotPoint = (prevMonthHigh + prevMonthLow + close ) / 3 
 Resistances: 
R3, R2, R1: Monthly resistance levels
 // Function to calculate additional pivot points based on the monthly data
getMonthlyPivotPoints() =>
      = getPrevMonthHighLow()
    pivotPoint = (prevMonthHigh + prevMonthLow + close ) / 3
    r1 = (2 * pivotPoint) - prevMonthLow
    s1 = (2 * pivotPoint) - prevMonthHigh
    r2 = pivotPoint + (prevMonthHigh - prevMonthLow)
    s2 = pivotPoint - (prevMonthHigh - prevMonthLow)
    r3 = prevMonthHigh + 2 * (pivotPoint - prevMonthLow)
    s3 = prevMonthLow - 2 * (prevMonthHigh - pivotPoint)
     
 Initializing and Populating the Table: 
The myTable variable initializes the table with a blue background, and subsequent table.cell functions populate the table with headers and data.
 // Initialize the table with adjusted bgcolor
var myTable = table.new(position = iPosition, columns = 5, rows = 10, bgcolor = color.new(color.blue, 90), border_width = 1, border_color = color.new(color.blue, 70)) 
 Dynamic Data Population: 
Data is dynamically populated in the table using the calculated values for Monthly Extremums, Weekly Extremums, Monthly Pivot Points, Resistances, and Supports.
 // Add rows dynamically with data
  = getPrevMonthHighLow()
  = getPrevWeekHighLow()
  = getMonthlyPivotPoints() 
---
 Conclusion: 
The Adaptive MFT Extremum Pivots indicator offers traders a detailed and clear representation of critical market levels, empowering them to make informed decisions. However, users should carefully analyze the market and consider their individual risk tolerance before making any trading decisions. The indicator's disclaimer emphasizes that it is not investment advice, and the author and script provider are not responsible for any financial losses incurred.
---
 Disclaimer: 
This indicator is not investment advice. Trading decisions should be made based on a careful analysis of the market and individual risk tolerance. The author and script provider are not responsible for any financial losses incurred.
 Kind regards,
Ely
Custom Lot Size Table with Calculator This TradingView script, is designed to empower traders with precise risk management tools. It allows for input of key parameters such as account balance, desired risk percentage, and a range for stop-loss pips, ensuring that the lot sizes calculated are perfectly aligned with risk tolerances.
The script dynamically adjusts the table size based on the user's input, offering a clear and concise visualization of the appropriate lot sizes..
Time & Sales (Tape) [By MUQWISHI]▋ INTRODUCTION : 
The “Time and Sales” (Tape) indicator generates trade data, including time, direction, price, and volume for each executed trade on an exchange. This information is typically delivered in real-time on a tick-by-tick basis or lower timeframe, providing insights into the traded size for a specific security.
_______________________
 ▋ OVERVIEW: 
  
_______________________
 ▋ Volume Dynamic Scale Bar: 
It's a way for determining dominance on the time and sales table, depending on the selected length (number of rows), indicating whether buyers or sellers are in control in selected length.
  
_______________________
 ▋ INDICATOR SETTINGS: 
 #Section One: Table Settings 
  
 #Section Two: Technical Settings 
  
(1) Implement By: Retrieve data by
  (1A) Lower Timeframe: Fetch data from the selected lower timeframe.
  (1B) Live Tick: Fetch data in real-time on a tick-by-tick basis, capturing data as soon as it's observed by the system.
(2) Length (Number of Rows): User able to select number of rows.
(3) Size Type: Volume OR Price Volume. 
 
_____________________
 ▋ COMMENT: 
The values in a table should not be taken as a major concept to build a trading decision.
Please let me know if you have any questions.
Thank you.
StrategyDashboardLibrary ”StrategyDashboard”
Hey, everybody!
I haven’t done anything here for a long time, I need to get better ^^.
In my strategies, so far private, but not about that, I constantly use dashboards, which clearly show how my strategy is working out.
Of course, you can also find a number of these parameters in the standard strategy window, but I prefer to display everything on the screen, rather than digging through a bunch of boxes and dropdowns.
At the moment I am using 2 dashboards, which I would like to share with you.
1. monthly(isShow)
this is a dashboard with the breakdown of profit by month in per cent. That is, it displays how much percentage you made or lost in a particular month, as well as for the year as a whole.
Parameters:
  isShow (bool) - determine allowance to display or not.
2. total(isShow)
The second dashboard displays more of the standard strategy information, but in a table format. Information from the series “number of consecutive losers, number of consecutive wins, amount of earnings per day, etc.”.
Parameters:
  isShow (bool) - determine allowance to display or not.
Since I prefer the dark theme of the interface, now they are adapted to it, but in the near future for general convenience I will add the ability to adapt to light.
The same goes for the colour scheme, now it is adapted to the one I use in my strategies (because the library with more is made by cutting these dashboards from my strategies), but will also make customisable part.
If you have any wishes, feel free to write in the comments, maybe I can implement and add them in the next versions.
TableLibrary   "Table" 
This library provides an easy way to convert arrays and matrixes of data into tables. There are a few different implementations of each function so you can get more or less control over the appearance of the tables. The basic rule of thumb is that all matrix rows must have the same number of columns, and if you are providing multiple arrays/matrixes to specify additional colors (background/text), they must have the same number of rows/columns as the data array. Finally, you do have the option of spanning cells across rows or columns with some special syntax in the data cell. Look at the examples to see how the arrays and matrixes need to be built before they can be used by the functions.
 floatArrayToCellArray(floatArray) 
  Helper function that converts a float array to a Cell array so it can be rendered with the fromArray function
  Parameters:
     floatArray (float ) : (array) the float array to convert to a Cell array.
  Returns: array The Cell array to return.
 stringArrayToCellArray(stringArray) 
  Helper function that converts a string array to a Cell array so it can be rendered with the fromArray function
  Parameters:
     stringArray (string ) : (array) the array to convert to a Cell array.
  Returns: array The Cell array to return.
 floatMatrixToCellMatrix(floatMatrix) 
  Helper function that converts a float matrix to a Cell matrix so it can be rendered with the fromMatrix function
  Parameters:
     floatMatrix (matrix) : (matrix) the float matrix to convert to a string matrix.
  Returns: matrix The Cell matrix to render.
 stringMatrixToCellMatrix(stringMatrix) 
  Helper function that converts a string matrix to a Cell matrix so it can be rendered with the fromMatrix function
  Parameters:
     stringMatrix (matrix) : (matrix) the string matrix to convert to a Cell matrix.
  Returns: matrix The Cell matrix to return.
 fromMatrix(CellMatrix, position, verticalOffset, transposeTable, textSize, borderWidth, tableNumRows, blankCellText) 
  Takes a CellMatrix and renders it as a table.
  Parameters:
     CellMatrix (matrix) : (matrix) The Cells to be rendered in a table
     position (string) : (string) Optional. The position of the table. Defaults to position.top_right
     verticalOffset (int) : (int) Optional. The vertical offset of the table from the top or bottom of the chart. Defaults to 0.
     transposeTable (bool) : (bool) Optional. Will transpose all of the data in the matrices before rendering. Defaults to false.
     textSize (string) : (string) Optional. The size of text to render in the table. Defaults to size.small.
     borderWidth (int) : (int) Optional. The width of the border between table cells. Defaults to 2.
     tableNumRows (int) : (int) Optional. The number of rows in the table. Not required, defaults to the number of rows in the provided matrix. If your matrix will have a variable number of rows, you must provide the max number of rows or the function will error when it attempts to set a cell value on a row that the table hadn't accounted for when it was defined.
     blankCellText (string) : (string) Optional. Text to use cells when adding blank rows for vertical offsetting.
 fromMatrix(dataMatrix, position, verticalOffset, transposeTable, textSize, borderWidth, tableNumRows, blankCellText) 
  Renders a float matrix as a table.
  Parameters:
     dataMatrix (matrix) : (matrix_float) The data to be rendered in a table
     position (string) : (string) Optional. The position of the table. Defaults to position.top_right
     verticalOffset (int) : (int) Optional. The vertical offset of the table from the top or bottom of the chart. Defaults to 0.
     transposeTable (bool) : (bool) Optional. Will transpose all of the data in the matrices before rendering. Defaults to false.
     textSize (string) : (string) Optional. The size of text to render in the table. Defaults to size.small.
     borderWidth (int) : (int) Optional. The width of the border between table cells. Defaults to 2.
     tableNumRows (int) : (int) Optional. The number of rows in the table. Not required, defaults to the number of rows in the provided matrix. If your matrix will have a variable number of rows, you must provide the max number of rows or the function will error when it attempts to set a cell value on a row that the table hadn't accounted for when it was defined.
     blankCellText (string) : (string) Optional. Text to use cells when adding blank rows for vertical offsetting.
 fromMatrix(dataMatrix, position, verticalOffset, transposeTable, textSize, borderWidth, tableNumRows, blankCellText) 
  Renders a string matrix as a table.
  Parameters:
     dataMatrix (matrix) : (matrix_string) The data to be rendered in a table
     position (string) : (string) Optional. The position of the table. Defaults to position.top_right
     verticalOffset (int) : (int) Optional. The vertical offset of the table from the top or bottom of the chart. Defaults to 0.
     transposeTable (bool) : (bool) Optional. Will transpose all of the data in the matrices before rendering. Defaults to false.
     textSize (string) : (string) Optional. The size of text to render in the table. Defaults to size.small.
     borderWidth (int) : (int) Optional. The width of the border between table cells. Defaults to 2.
     tableNumRows (int) : (int) Optional. The number of rows in the table. Not required, defaults to the number of rows in the provided matrix. If your matrix will have a variable number of rows, you must provide the max number of rows or the function will error when it attempts to set a cell value on a row that the table hadn't accounted for when it was defined.
     blankCellText (string) : (string) Optional. Text to use cells when adding blank rows for vertical offsetting.
 fromArray(dataArray, position, verticalOffset, transposeTable, textSize, borderWidth, blankCellText) 
  Renders a Cell array as a table.
  Parameters:
     dataArray (Cell ) : (array) The data to be rendered in a table
     position (string) : (string) Optional. The position of the table. Defaults to position.top_right
     verticalOffset (int) : (int) Optional. The vertical offset of the table from the top or bottom of the chart. Defaults to 0.
     transposeTable (bool) : (bool) Optional. Will transpose all of the data in the matrices before rendering. Defaults to false.
     textSize (string) : (string) Optional. The size of text to render in the table. Defaults to size.small.
     borderWidth (int) : (int) Optional. The width of the border between table cells. Defaults to 2.
     blankCellText (string) : (string) Optional. Text to use cells when adding blank rows for vertical offsetting.
 fromArray(dataArray, position, verticalOffset, transposeTable, textSize, borderWidth, blankCellText) 
  Renders a string array as a table.
  Parameters:
     dataArray (string ) : (array_string) The data to be rendered in a table
     position (string) : (string) Optional. The position of the table. Defaults to position.top_right
     verticalOffset (int) : (int) Optional. The vertical offset of the table from the top or bottom of the chart. Defaults to 0.
     transposeTable (bool) : (bool) Optional. Will transpose all of the data in the matrices before rendering. Defaults to false.
     textSize (string) : (string) Optional. The size of text to render in the table. Defaults to size.small.
     borderWidth (int) : (int) Optional. The width of the border between table cells. Defaults to 2.
     blankCellText (string) : (string) Optional. Text to use cells when adding blank rows for vertical offsetting.
 fromArray(dataArray, position, verticalOffset, transposeTable, textSize, borderWidth, blankCellText) 
  Renders a float array as a table.
  Parameters:
     dataArray (float ) : (array_float) The data to be rendered in a table
     position (string) : (string) Optional. The position of the table. Defaults to position.top_right
     verticalOffset (int) : (int) Optional. The vertical offset of the table from the top or bottom of the chart. Defaults to 0.
     transposeTable (bool) : (bool) Optional. Will transpose all of the data in the matrices before rendering. Defaults to false.
     textSize (string) : (string) Optional. The size of text to render in the table. Defaults to size.small.
     borderWidth (int) : (int) Optional. The width of the border between table cells. Defaults to 2.
     blankCellText (string) : (string) Optional. Text to use cells when adding blank rows for vertical offsetting.
 debug(message, position) 
  Renders a debug message in a table at the desired location on screen.
  Parameters:
     message (string) : (string) The message to render.
     position (string) : (string) Optional. The position of the debug message. Defaults to position.middle_right.
 Cell 
  Type for each cell's content and appearance
  Fields:
     content (series string) 
     bgColor (series color) 
     textColor (series color) 
     align (series string) 
     colspan (series int) 
     rowspan (series int)
Market Performance TableThe Market Performance Table displays the performance of multiple tickers (up to 5) in a table format. The tickers can be customized by selecting them through the indicator settings.
The indicator calculates various metrics for each ticker, including the 1-day change percentage, whether the price is above the 50, 20, and 10-day simple moving averages (SMA), as well as the relative strength compared to the 10/20 SMA and 20/50 SMA crossovers. It also calculates the price deviation from the 50-day SMA.
The table is displayed on the chart and can be positioned in different locations.
Credits for the idea to @Alex_PrimeTrading ;)
TradersCheckListThe Traders Check List is a unique and innovative tool designed to assist traders in their decision-making process. Unlike traditional indicators that provide signals or visual representations of market data, the Traders Check List offers a structured and customizable checklist that traders can use to ensure they're adhering to their trading plan and strategy.
While there are countless indicators available for trend detection, momentum, volatility, and other market aspects, very few tools focus on the trader's process. The Traders Check List fills this gap by providing a visual reminder of key trading considerations directly on the chart.
Functionality:
Upon applying the Traders Check List to a chart, users will see a table displayed, typically in the top right corner. This table contains rows that represent different trading considerations, such as trend direction, risk management, and psychological factors. Each row can be customized by the user to fit their specific trading plan.
For instance, a trader might have a row labeled "Trending Lower" with a corresponding "Yes/No" column to confirm if the current instrument is indeed trending downward.
Underlying Concepts:
The Traders Check List is based on the principle that successful trading is not just about market analysis but also about discipline and consistency. By having a visual checklist on the chart, traders are constantly reminded of their strategy's key components, reducing the likelihood of impulsive or emotional decisions.
How to Use:
Apply the Traders Check List to your desired chart.
Customize the rows based on your trading strategy's key considerations.
As you analyze the market, update the checklist to reflect the current conditions and your analysis.
Before entering a trade, review the checklist to ensure all criteria are met.
MMI Auto Backtesting StrategyDescription: 
A strategy based on ATR with auto-backtesting capabilities, Take Profit and Stop Loss (either Normal or Trailing). It allows you to select ranges of values and step for each parameter, and backtest the strategy on a multitude of input combinations at once. You can alternatively use a constant value for each parameter. The backtesting results strive to be as close as possible to those given by Tradingview Strategy Tester.
The strategy displays a table with results for different input combinations. This has columns showing current input combination as well as the following stats: Net Profit, Number of trades, % of Profitable trades, Profit Factor, Max Drawdown, Max Runup, Average Trade and Average number of bars in a trade. 
You can sort the table by any column (including sorting by multiple columns at the same time) to find, for example, input combination that gives highest Net Profit (or, if sorting by multiple columns, to find input combination with the best balance of Net Profit and % of Profitable trades). You can filter by any column as well (or multiple columns at the same time), using logical expressions like "< value", "> value", "<= value", ">= value". And you can use logical expressions like "< value%" for Net Profit, Max Drawdown, Max Runup and Average trade to filter by percentage value. You will see a "↓" symbol in column's header if that column is sorted from Highest to Lowest, a "↑" symbol if it's sorted from Lowest to Highest and a "𐕢" symbol if that column is being filtered. 
The table has customisable styles (like text color, background color of cells, etc.), and can show the total number of backtested combinations with the time taken to test them. You can also change Initial Capital and Position Size (either Contracts, Currency or % of Equity). 
 Parameters: 
The following parameters are located in the "INPUTS (USUAL STRATEGY)" group, and control the behaviour of strategy itself (not the auto-backtesting functionality):
- Period: ATR Length
- Multiplier: ATR Multiplier
- DPO: length of the filtering moving average
- SL: stop loss
- TP: take profit
- Use Stop Loss: enable stop loss
- Stop Loss Mode: stop loss mode (either Normal or Trailing)
- Use Take Profit: enable take profit
- Wicks: use high & low price, or close price
The strategy also has various parameters separated by different groups:
- INPUTS (AUTO-BACKTESTING): has the same parameters as the "INPUTS (USUAL STRATEGY)" group, but controls the input combinations for auto-backtesting; all the numeric parameters have 3 values: F/V (from), T (to) and S (step); if the checkbox to the left of F/V parameter is off, the value of F/V will indicate the constant value used for that parameter (if the checkbox is on, the values will be from F/V to T using step S)
- STRATEGY: contains strategy related parameters like Initial Capital and Position Size
- BACKTESTING: allows you to display either Percentage, Absolute or Both values in the table and has checkboxes that allow you to exclude certain columns from the table
- SORTING: allows you to select sorting mode (Highest to Lowest or vice versa) and has checkboxes in case you want to sort by multiple columns at the same time
- FILTERING: has a text field for each column of the strategy where you can type logical expressions to filter the values 
- TABLE: contains styling parameters
Many parameters have the "(i)" description marker, so hover over it to see more details. 
 Problems: 
- The script works best on lower timeframes and continuous markets (trades 24/7), in other cases the backtesting results may vary from those that Tradingview shows
- The script shows closest results when Take Profit and Stop Loss are not used
- Max Runup percentage value is often wrong
 Limitations: 
- As we are limited by the maximum time a script can be running (which is 20s for Free plan and 40s for Paid plans), we can only backtest several hundreds of combinations within that timeframe (though it depends on the parameters, market and timeframe of the chart you use) 
All Candlestick Patterns on Backtest [By MUQWISHI]▋ INTRODUCTION : 
The “All Candlestick Patterns on Backtest” indicator generates a table that offers a clear visualization of the historical return percentages for each candlestick pattern strategy over a specified time period. This table serves as an organized resource, serving as a launching point for in-depth research into candle formations. It may help to rectify any misconceptions surrounding candlestick patterns, refine trading approaches, and it could be foundation to make informed decisions in trading journey.
_______________________
 ▋ OVERVIEW: 
  
_______________________
 ▋ CREDIT: 
Credit to public technical “*All Candlestick Patterns*” indicator.
  
_______________________
 ▋ TABLE: 
  
_______________________
 ▋ CHART: 
  
_______________________
 ▋ INDICATOR SETTINGS: 
 #Section One: Table Setting 
  
 #Section Two: Backtest Setting 
  
(1) Backtest Starting Period. 
 Note: If the datetime of the first candle on the chart is after the entreated datetime, the calculation will start from the first candle on the chart.
(2) Initial Equity ($). 
(3) Leverage: Current Equity x Leverage Value. 
(4) Entry Mode: 
 - “At Close”: Execute entry order as soon as the candle confirmed.
 - “Breakout High (Low for Short)”: Stop limit buy order, entry order will be executed as soon as the next candle breakout the high of last pattern’s candle (low for short)
(5) Cancel Entry Within Bars: This option is applicable with {Entry Mode = Breakout High (Low for Short)}, to cancel the Entry Order if it's not executed within certain selected number of bars.
(6) Stoploss Range: the range refers to high of pattern - low of pattern.
  
(7) Risk:Reward: the calculation of risk:reward range start from entry price level. For example: A pattern triggered with range 10 points, and entry price is 100. 
 - For 1:1~risk:reward would the stoploss at 90 and takeprofit at 110. 
 - For 1:3~risk:reward would the stoploss at 90 and takeprofit at 130.
 #Section Three: Technical & Candle Patterns 
  
_______________________
 ▋ Comments: 
 
 This table was developed for research and educational purposes. 
 Candlestick patterns are almost similar as seen in “*All Candlestick Patterns*” indicator.
 The table results should not be taken as a major concept to build a trading decision. 
 Personally, I see candlestick patterns as a means to comprehend the psychology of the market, and help to follow the price action.
 
Please let me know if you have any questions.
Thank you.
SYMBOL - TIME - SECTOR - INDUSTRYI wanted to make something that i find is useful to show the information on the underlying stock symbol that can be moved around to fit other indicators. sometimes the stock version of the logo and symbol and time gets smashed in the top left hand corner and it would be nice to see a little more information if buzzing though a bunch of different stocks or whatever.
I made to easy to move around and take fields on / off
i hope this one actually doesnt get flagged there should be anything from anyone elses code.
more importantly i hope it helps those people who have lots of stuff going on so we know what they are looking at... 
imlibLibrary "imlib"
 Description 
The library allows you to display images in your scripts utilising the  objects. You can change the image size and screen aspect ratio (the ratio of width to height which you can change if the image is too wide / tall). The library has "example()" function which you can use to see how it works. It also has a handy "logo()" function which you can use to quickly display an image by passing the "Image data string", table position, image size and aspect ratio. And of course you can use it in your own custom way by taking the "logo()" function as an example and modifying the code to your needs.
Since tables in Pinescript are limited to 100 by 100 cells, the limit for image's size is also 100x100 px. All the necessary data to display an image is passed as a string variable, and since Pinescript has a limit of 4096 characters for variables of  type, that string can have a maximum length of 4096 characters, which is enough to display a 64x64px image (but can be enough to display a 100x100 image, depending on the image itself).
Below you can find the definitions of functions for this library.
 _decompress(data) 
  : Decompresses string with data image
  Parameters:
     data (string) 
  Returns: : Array of  with decompressed data
 load(data) 
  : Splits the string with image data into components and builds an  object
  Parameters:
     data (string) 
  Returns: : An  object
 show(imgdata, table_id, image_size, screen_ratio) 
  : Displays an image in a table
  Parameters:
     imgdata (ImgData) 
     table_id (table) 
     image_size (float) 
     screen_ratio (string) 
  Returns: : nothing
 example() 
  : Use it as an example of how this library works and how to use it in your own scripts
  Returns: : nothing
 logo(imgdata, position, image_size, screen_ratio) 
  : Displays logo using image data string
  Parameters:
     imgdata (string) 
     position (string) 
     image_size (float) 
     screen_ratio (string) 
  Returns: : nothing
 ImgData 
  Fields:
     w (series__integer) 
     h (series__integer) 
     s (series__string) 
     pal (series__string) 
     data (array__string)
CandlesGroup_TypesLibrary   "CandlesGroup_Types" 
CandlesGroup Type allows you to efficiently store and access properties of all the candles in your chart.
You can easily manipulate large datasets, work with multiple timeframes, or analyze multiple symbols simultaneously. By encapsulating the properties of each candle within a CandlesGroup object, you gain a convenient and organized way to handle complex candlestick patterns and data.
For usage instructions and detailed examples, please refer to the comments and examples provided in the source code.
 method init(_self) 
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) 
 method init(_self, propertyNames) 
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) 
     propertyNames (string ) 
 method get(_self, key) 
  get values array from a given property name
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     key (string) : : key name of selected property. Default is "index"
  Returns: values array
 method size(_self) 
  get size of values array. By default it equals to current bar_index
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
  Returns: size of values array
 method push(_self, key, value) 
  push single value to specific property
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     key (string) : : key name of selected property
     value (float) : : property value
  Returns: CandlesGroup object
 method push(_self, arr) 
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) 
     arr (float ) 
 method populate(_self, ohlc) 
  populate ohlc to CandlesGroup
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     ohlc (float ) : : array of ohlc
  Returns: CandlesGroup object
 method populate(_self, values, propertiesNames) 
  populate values base on given properties Names
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     values (float ) : : array of property values
     propertiesNames (string ) : : an array stores property names. Use as keys to get values
  Returns: CandlesGroup object
 method populate(_self) 
  populate values (default setup)
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
  Returns: CandlesGroup object
 method lookback(arr, bars_lookback) 
  get property value on previous candles. For current candle, use *.lookback()
  Namespace types: float 
  Parameters:
     arr (float ) : : array of selected property values
     bars_lookback (int) : : number of candles lookback. 0 = current candle. Default is 0
  Returns: single property value
 method highest_within_bars(_self, hiSource, start, end, useIndex) 
  get the highest property value between specific candles
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     hiSource (string) : : key name of selected property
     start (int) : : start bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true
     end (int) : : end bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true. Default is 0
     useIndex (bool) : : use index instead of lookback value. Default = false
  Returns: the highest value within candles
 method highest_within_bars(_self, returnWithIndex, hiSource, start, end, useIndex) 
  get the highest property value and bar index between specific candles
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     returnWithIndex (bool) : : the function only applicable when it is true
     hiSource (string) : : key name of selected property
     start (int) : : start bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true
     end (int) : : end bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true. Default is 0
     useIndex (bool) : : use index instead of lookback value. Default = false
  Returns:  
 method highest_point_within_bars(_self, hiSource, start, end, useIndex) 
  get a Point object which contains highest property value between specific candles
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     hiSource (string) : : key name of selected property
     start (int) : : start bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true
     end (int) : : end bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true. Default is 0
     useIndex (bool) : : use index instead of lookback value. Default = false
  Returns: Point object contains highest property value
 method lowest_within_bars(_self, loSource, start, end, useIndex) 
  get the lowest property value between specific candles
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     loSource (string) : : key name of selected property
     start (int) : : start bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true
     end (int) : : end bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true. Default is 0
     useIndex (bool) : : use index instead of lookback value. Default = false
  Returns: the lowest value within candles
 method lowest_within_bars(_self, returnWithIndex, loSource, start, end, useIndex) 
  get the lowest property value and bar index between specific candles
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     returnWithIndex (bool) : : the function only applicable when it is true
     loSource (string) : : key name of selected property
     start (int) : : start bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true
     end (int) : : end bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true. Default is 0
     useIndex (bool) : : use index instead of lookback value. Default = false
  Returns:  
 method lowest_point_within_bars(_self, loSource, start, end, useIndex) 
  get a Point object which contains lowest property value between specific candles
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     loSource (string) : : key name of selected property
     start (int) : : start bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true
     end (int) : : end bar for calculation. Default is candles lookback value from current candle. 'index' value is used if 'useIndex' = true. Default is 0
     useIndex (bool) : : use index instead of lookback value. Default = false
  Returns: Point object contains lowest property value
 method time2bar(_self, t) 
  Convert UNIX time to bar index of active chart
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     t (int) : : UNIX time
  Returns: bar index
 method time2bar(_self, timezone, YYYY, MMM, DD, hh, mm, ss) 
  Convert timestamp to bar index of active chart. User defined timezone required
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     timezone (string) : : User defined timezone
     YYYY (int) : : Year
     MMM (int) : : Month
     DD (int) : : Day
     hh (int) : : Hour. Default is 0
     mm (int) : : Minute. Default is 0
     ss (int) : : Second. Default is 0
  Returns: bar index
 method time2bar(_self, YYYY, MMM, DD, hh, mm, ss) 
  Convert timestamp to bar index of active chart
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     YYYY (int) : : Year
     MMM (int) : : Month
     DD (int) : : Day
     hh (int) : : Hour. Default is 0
     mm (int) : : Minute. Default is 0
     ss (int) : : Second. Default is 0
  Returns: bar index
 method get_prop_from_time(_self, key, t) 
  get single property value from UNIX time
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     key (string) : : key name of selected property
     t (int) : : UNIX time
  Returns: single property value
 method get_prop_from_time(_self, key, timezone, YYYY, MMM, DD, hh, mm, ss) 
  get single property value from timestamp. User defined timezone required
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     key (string) : : key name of selected property
     timezone (string) : : User defined timezone
     YYYY (int) : : Year
     MMM (int) : : Month
     DD (int) : : Day
     hh (int) : : Hour. Default is 0
     mm (int) : : Minute. Default is 0
     ss (int) : : Second. Default is 0
  Returns: single property value
 method get_prop_from_time(_self, key, YYYY, MMM, DD, hh, mm, ss) 
  get single property value from timestamp
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     key (string) : : key name of selected property
     YYYY (int) : : Year
     MMM (int) : : Month
     DD (int) : : Day
     hh (int) : : Hour. Default is 0
     mm (int) : : Minute. Default is 0
     ss (int) : : Second. Default is 0
  Returns: single property value
 method bar2time(_self, index) 
  Convert bar index of active chart to UNIX time
  Namespace types: CandlesGroup
  Parameters:
     _self (CandlesGroup) : : CandlesGroup object
     index (int) : : bar index
  Returns: UNIX time
 Point 
  A point on chart
  Fields:
     price (series float) : : price value
     bar (series int) : : bar index
     bartime (series int) : : time in UNIX format of bar
 Property 
  Property object which contains values of all candles
  Fields:
     name (series string) : : name of property
     values (float ) : : an array stores values of all candles. Size of array = bar_index
 CandlesGroup 
  Candles Group object which contains properties of all candles
  Fields:
     propertyNames (string ) : : an array stores property names. Use as keys to get values
     properties (Property ) : : array of Property objects
TRADE WITH MACDThis indicator is used to identify the trend through the background color and by using the MACD indicator information and summarizing the moving average information and identifying the trend through the integration of information and then warning the fall and growth of the price of Bitcoin relative to the successful entry into any transaction by the trader. it helps
Some features of this indicator:
- The table draws the time frames in the desired time period quickly and accurately
- Identifying and inserting ascending and descending trends
- View the chart of five moving averages (9, 20, 50, 100, 200) at the same time
- Draw charts automatically or draw a chart with the desired interval length and desired start time
- Automatic updating of price data charts
- Changing the background color and warning in separate time frames from the current time frame as desired by the trader
.print()
You don't need to initialize anything.. 
After you import the library you can use .print() as easy as that..! 
Hope this helps
* use a unique ID for each .print() call 
let me know if you run into any bugs 
by trying to make it as user friendly as possible i had to do 
some not ideal things so there's a chance it could present some bugs with 
a lot of labels present on the chart
and if you use label.all to parse and manipulate the labels on the chart..
most likely it will cause an issue but not a lot of people use this so 
I don't think that will be a problem.
thanks,
FFriZz | frizlabz 
Library   "print" 
Single function to print any type to console
 method str(inp) 
  `method` convert all types to string
```
(overload)
*.str(any inp) => string
```
  Namespace types: series string, simple string, input string, const string
  Parameters:
     inp (string) : `any` - desc | Required
  Returns: `string` formatted string
 method str(inp) 
  Namespace types: series int, simple int, input int, const int
  Parameters:
     inp (int) 
 method str(inp) 
  Namespace types: series float, simple float, input float, const float
  Parameters:
     inp (float) 
 method str(inp) 
  Namespace types: series bool, simple bool, input bool, const bool
  Parameters:
     inp (bool) 
 method str(inp) 
  Namespace types: series linefill
  Parameters:
     inp (linefill) 
 method str(inp) 
  Namespace types: series line
  Parameters:
     inp (line) 
 method str(inp) 
  Namespace types: series box
  Parameters:
     inp (box) 
 method str(inp) 
  Namespace types: series label
  Parameters:
     inp (label) 
 method str(inp) 
  Namespace types: matrix
  Parameters:
     inp (matrix) 
 method str(inp) 
  Namespace types: matrix
  Parameters:
     inp (matrix) 
 method str(inp) 
  Namespace types: matrix
  Parameters:
     inp (matrix) 
 method str(inp) 
  Namespace types: matrix
  Parameters:
     inp (matrix) 
 method str(inp) 
  Namespace types: matrix
  Parameters:
     inp (matrix) 
 method str(inp) 
  Namespace types: matrix
  Parameters:
     inp (matrix) 
 method str(inp) 
  Namespace types: matrix
  Parameters:
     inp (matrix) 
 method str(inp) 
  Namespace types: matrix
  Parameters:
     inp (matrix) 
 method str(inp) 
  Namespace types: linefill 
  Parameters:
     inp (linefill ) 
 method str(inp) 
  Namespace types: line 
  Parameters:
     inp (line ) 
 method str(inp) 
  Namespace types: box 
  Parameters:
     inp (box ) 
 method str(inp) 
  Namespace types: label 
  Parameters:
     inp (label ) 
 method str(inp) 
  Namespace types: string 
  Parameters:
     inp (string ) 
 method str(inp) 
  Namespace types: int 
  Parameters:
     inp (int ) 
 method str(inp) 
  Namespace types: float 
  Parameters:
     inp (float ) 
 method str(inp) 
  Namespace types: bool 
  Parameters:
     inp (bool ) 
 method arrayShorten(str) 
  arrayShorten
  Namespace types: series string, simple string, input string, const string
  Parameters:
     str (string) : `string` - the string to shorten | Required
  Returns: `string` - a shortened version of the input string if it is an array with more than 7 elements, otherwise the original string
 method matrixShorten(str) 
  matrixShorten
  Namespace types: series string, simple string, input string, const string
  Parameters:
     str (string) : `string` - the string to shorten | Required
  Returns: `string` - the shortened matrix string if the input is a matrix, otherwise returns the input string as is
 method print(x, ID) 
  print all types to theh same console with just this `method/function`
```
(overload)
*.print(any x, string ID, bool shorten=true?) => console
"param 'shorten' - only for arrays and matrixs" | true 
```
  Namespace types: series string, simple string, input string, const string
  Parameters:
     x (string) : - `any` input to convert
     ID (string) : - `string` unique id for label on console `MUST BE UNIQUE`
  Returns: adds the `ID` and the `inp` to the console on the chart
 method print(x, ID) 
  Namespace types: series float, simple float, input float, const float
  Parameters:
     x (float) 
     ID (string) 
 method print(x, ID) 
  Namespace types: series int, simple int, input int, const int
  Parameters:
     x (int) 
     ID (string) 
 method print(x, ID) 
  Namespace types: series box
  Parameters:
     x (box) 
     ID (string) 
 method print(x, ID) 
  Namespace types: series bool, simple bool, input bool, const bool
  Parameters:
     x (bool) 
     ID (string) 
 method print(x, ID) 
  Namespace types: series label
  Parameters:
     x (label) 
     ID (string) 
 method print(x, ID) 
  Namespace types: series line
  Parameters:
     x (line) 
     ID (string) 
 method print(x, ID) 
  Namespace types: series linefill
  Parameters:
     x (linefill) 
     ID (string) 
 method print(x, ID, shorten) 
  Namespace types: string 
  Parameters:
     x (string ) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: float 
  Parameters:
     x (float ) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: int 
  Parameters:
     x (int ) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: box 
  Parameters:
     x (box ) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: bool 
  Parameters:
     x (bool ) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: label 
  Parameters:
     x (label ) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: line 
  Parameters:
     x (line ) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: linefill 
  Parameters:
     x (linefill ) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: matrix
  Parameters:
     x (matrix) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: matrix
  Parameters:
     x (matrix) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: matrix
  Parameters:
     x (matrix) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: matrix
  Parameters:
     x (matrix) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: matrix
  Parameters:
     x (matrix) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: matrix
  Parameters:
     x (matrix) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: matrix
  Parameters:
     x (matrix) 
     ID (string) 
     shorten (bool) 
 method print(x, ID, shorten) 
  Namespace types: matrix
  Parameters:
     x (matrix) 
     ID (string) 
     shorten (bool)
Monthly Strategy Performance TableWhat Is This? 
This script code adds a Monthly Strategy Performance Table to your Pine Script strategy scripts so you can see a month-by-month and year-by-year breakdown of your P&L as a percentage of your account balance.
The table is based on realized equity rather than open equity, so it only updates the metrics when a trade is closed. 
That's why some numbers will not match the Strategy Tester metrics (such as max drawdown), as the Strategy Tester bases metrics like max drawdown on open trade equity and not realized equity (closed trades).
The script is still a work-in-progress, so make sure to read the disclaimer below. But I think it's ready to release the code for others to play around with.
 How To Use It 
The script code includes one of my strategies as an example strategy. You need to replace my strategy code with your own. To do that just copy the source code below into a blank script, delete lines 11 -> 60 and paste your strategy code in there instead of mine. The script should work with most systems, but make sure to read the disclaimer below.
It works best with a significant amount of historical data, so it may not work very effectively on intraday timeframes as there is a severe limitation of available bars on TradingView. I recommend using it on 4HR timeframes and above, as anything less will produce very little usable data. Having a premium TradingView plan will also help boost the number of available bars.
You can hover your mouse over a table cell to get more information in the form of tooltips (such as the Long and Short win rate if you hover over your total return cell).
 Credit 
The code in this script is based on open-source code originally written by QuantNomad, I've made significant changes and additions to the original script but all credit for the idea and especially the display table code goes to them - I just built on top of it:
  
 Why Did I Make This? 
None of this is trading or investment advice, just my personal opinion based on my experience as a trader and systems developer these past 6+ years:
The TradingView Strategy Tester is severely limited in some important ways. And unless you use complex Excel formulas on exported test data, you can't see a granular perspective of your system's historical performance.
There is much more to creating profitable and tradeable systems than developing a strategy with a good win rate and a good return with a reasonable drawdown.
Some additional questions we need to ask ourselves are:
 
 What did the system's worst drawdown look like?
 How long did it last?
 How often do drawdowns occur, and how quickly are they typically recovered?
 How often do we have a break-even or losing month or year?
 What is our expected compounded annual growth rate, and how does that growth rate compare to our max drawdown?
 
And many more questions that are too long to list and take a lifetime of trading experience to answer.
Without answering these kinds of questions, we run the risk of developing systems that look good on paper, but when it comes to live trading, we are uncomfortable or incapable of enduring the system's granular characteristics.
This Monthly Performance Table script code is intended to help bridge some of that gap with the Strategy Tester's limited default performance data.
 Disclaimer 
I've done my best to ensure the numbers this code outputs are accurate, and according to my testing with my personal strategy scripts it appears to work fine. But there is always a good chance I've missed something, or that this code will not work with your particular system.
The majority of my TradingView systems are extremely simple single-target systems that operate on a closed-candle basis to minimize many of the data reliability issues with the Strategy Tester, so I was unable to do much testing with multiple targets and pyramiding etc.
I've included a Debug option in the script that will display important data and information on a label each time a trade is closed. I recommend using the Debug option to confirm that the numbers you see in the table are accurate and match what your strategy is actually doing.
Always do your own due diligence, verify all claims as best you can, and never take anyone's word for anything.
Take care, and best of luck with your trading :)
Kind regards,
Matt.
 PS. If you're interested in learning how this script works, I have a free hour-long video lesson breaking down the source code - just check out the links below this script or in my profile.
RGB Color Codes Chart█ OVERVIEW 
This indicator is an educational indicator to make pine coders easier to input color code.
Color code displayed either in hex or rgb code or both.
 █ INSPIRATIONS 
 RGB Color Codes Chart 
  Table Color For Pairing Black And White 
 █ FEATURES 
 
  Hover table cell to see all properties of color such as Hex code and RGB code via tooltip.
  Cell can be show either Full, HEX, RGB, R, G, B or na.
 
 █ LIMITATION 
 
  This code does not consider usage of color.new()
 
 █ CONSIDERATION 
 
  Code consideration to be used such as color.r(), color.g(), color.b() and color.rgb()
 
 █ EXAMPLE OF USAGE / EXPLAINATION 
  
  
  
 






















