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
Table
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
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.
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.
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
.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 
  
  
  
 
toolsLibrary   "tools" 
A library of many helper methods, plus a comprehensive print method and a printer object.
This is a newer version of the  helpers  library. This script uses pinescripts v5 latest objects and methods.
TableBuilderLibrary   "TableBuilder" 
A helper library to make it simpler to create tables in pinescript
This is a simple table building library that I created because I personally feel that the built-in table building method is too verbose.  It features chaining methods and variable arguments.
There are many features that are lacking because the implementation is early, and there may be antipatterns because I am not familiar with the runtime behavior like pinescript. If you have any comments on code improvements or features you want, please comment :D
[-_-] 2D FractalsThe sole purpose of this script is to demonstrate what's possible to make with Pinescript, namely to display images (2D Fractals in this case). 
The script consists of two functions: one that generates the values of a fractal and one that displays them (utilising table) with each cell being used as a "pixel". We can control the "resolution" of image, as well as choose one of three fractal types.
MA Band Distance Monitor'MA Band Distance Monitor' indicator is a simple tool for traders who rely on moving averages to make trading decisions. This indicator plots two moving averages of your choice (you can select the type of the moving average), and fills the space between them, creating a "band".
The indicator also generates a table that displays the current price distance from both the fast and slow moving averages, as well as the average of the two. This allows you to quickly assess the strength of the trend and potential entry or exit points.
In addition, the table also shows the average price distance from one to another MA and also the current distance between them, allowing you to compare the current price action to the historical average. This information can help you identify potential trend reversals and assess the overall health of the market.
*** Slow length input must be greater than fast length input, otherwise indicator will produce faulty results
 
Elliot Wave Helper Table█  OVERVIEW 
This indicator is intend to be helper to help Elliot Wave user to properly Elliot Wave tools according to correct degree such as 12345 or ABCWXY. The abbreviation changes according to timeframe.
 █  FEATURES 
1. Abbreviation degree adaptive to timeframe. Eg : Subminutte for 1 minute chart, etc.
2. Works for custom timeframe. Eg : Subminutte for 1 to 4 minute chart, etc.
3. Show reference table if necessary.
 █  REFERENCE 
 Adaptive Elliot Wave Degree Chart 
  
 █  EXAMPLES / USAGES 
  
  
  
  
  
Harmonic Pattern Table UDT█  OVERVIEW
This table indicator was intended as helper / reference for using XABCD Pattern drawing tool.
The values shown in table was based on Harmonic Trading Volume 3: Reaction vs. Reversal written by Scott M Carney.
Code upgrade from  Harmonic Pattern Table (Source Code)  and based on latest  User-Defined Type (UDT) .
As a result, code appeared more cleaner.
█  FEATURES
1. List Harmonic Patterns.
2. Font size small for mobile app and font size normal for desktop.
3. Options to show Animal name in text, emoji or both.
█  USAGE
Similar to  Harmonic Pattern Table (Source Code). 
█  CREDITS
Scott M Carney, Trading Volume 3: Reaction vs. Reversal
TableBuilderTableBuilder  is a library designed to make it easier to create tables in PineScript.
It allows you to more flexibly define the structure of a table before actually building it.
Features:
 
 Style inheritance: styles are inherited from Table, to Column, to Row, and then Cell.
 Columns are useful for propagating/reusing style but they are not required.
 Add rows with different numbers of cells. The resultant number of columns in the table will be determined by the max number of cells vs the number of defined columns.
 Auto text color: Instead of having to set the font color for every cell, the color is automatically determined by the luminosity of the background color.
 
See the 'Demo' section of the code for an example.
Democratic Fibonacci Moving AveragesWith this indicator, we have taken moving averages at Fibonacci lengths (3 to 233) as well as the average of these values, labeled the DFMA. Additionally, these values have been inputted into a table overlay.  The cross of the FibMA(233) and the DFMA can be used as a signal for long or short.
The FibMA lengths of 3 and 233 are plotted in white by default, the FibMAs with lengths between 3 and 233 are plotted in blue by default, and the democratic line (DFMA) that averages these lines is plotted in green or red (depending on if the value is above or below the 233-length FibMA). 






















