Jump to content

Welcome to the new Traders Laboratory! Please bear with us as we finish the migration over the next few days. If you find any issues, want to leave feedback, get in touch with us, or offer suggestions please post to the Support forum here.

  • Welcome Guests

    Welcome. You are currently viewing the forum as a guest which does not give you access to all the great features at Traders Laboratory such as interacting with members, access to all forums, downloading attachments, and eligibility to win free giveaways. Registration is fast, simple and absolutely free. Create a FREE Traders Laboratory account here.

Soultrader

Soultrader's Pivots for Tradestation

Recommended Posts

This is a Tradestation release for custom pivot points. This indicator has been made to use the following formula:

 

Soultrader's Pivot Points

 

R3 = R1 + RANGE

R2 = PP + RANGE

R1 = (2 * PP) - LOW

PP = (HIGH + LOW + CLOSE) / 3

S1 = (2 * PP) - HIGH

S2 = PP - RANGE

S3 = S1 - RANGE

 

Following features:

 

1. Allows user to enable or disable midpoints.

2. Allows user to enable or disable weekly and monthly pivots.

3. User can change the color and style of horizontal lines. If you prefer dotted lines over solid, this can be changed.

4. Easy language code can be adjusted to fit your needs. If you prefer to use a different formula, this can be edited.

 

All you need to do is plot the high, low, and close and the indicator will draw the lines automatically on your charts.

 

All credits go out to Antonio (ant) for releasing this indicator. You may not redistribute this indicator without the permission of Antonio.

 

Special thanks goes out to Antonio for making this for me. It has helped me save alot of time.

 

Please click install if you download this indicator for notifications of upates.

SOULTRADERPIVOTS.ELD

Share this post


Link to post
Share on other sites

Soul:

Is there anyway to program each pivot levels' label? For example, "Daily R1" right above that particular pivot so as the day progresses the label stays visible in the area of the chart currently being viewed?

Share this post


Link to post
Share on other sites
Soul:

Is there anyway to program each pivot levels' label? For example, "Daily R1" right above that particular pivot so as the day progresses the label stays visible in the area of the chart currently being viewed?

 

Attached is the SoultraderPivots indicator with labels, excluding the midpoints. If you want labels for the midpoints, review the code and just follow suit. This enhancement has been requested by several people and the changes are fairly straightforward so I thought I'd make it available.

 

James, you may want to replace the original indicator with this one.

SOULTRADERPIVOTS.ELD

Share this post


Link to post
Share on other sites
When I put the soultrader pivots on my chart the labels show for a few seconds then disappear. Has anyone had the same problem?

 

Yes, until Ant told me to remove the selection "Update value intra-bar (tick-by-tick)" under the General tab when you format the analysis technique.

Share this post


Link to post
Share on other sites
Is there any similar indicator for esignal ?

These code are for esignal pivots. If someone can convert in tradestation it's arrange all the problem that indicator have.

 

philloo

 

 

 

Fix History:

 

02/02/2005 - Initial Release

1.0.0

 

=====================================================================

Project Description:

 

 

Dislaimer: For educational purposes only! Obviously, no guarantees

whatsoever and use at your own risk.

 

**********************************************************************/

 

// globals

var vOutputArray = null;

var vResultArray = null;

var vLastSeenDay = null;

 

//pivot line labels ( Daily, Weekly and Monthly)

var vTitleArray = new Array("R3", "M6", "R2", "M5", "R1", "M4", "PP", "M3", "S1", "M2", "S2", "M1", "S3");

var vLabelArray = new Array("Daily R3","Midpoint","Daily R2","Midpoint","Daily R1","Midpoint","Daily PP","Midpoint","Daily S1","Midpoint","Daily S2","Midpoint","Daily S3");

var vLabelArrayW = new Array("Weekly R3","WMidpoint","Weekly R2","WMidpoint","Weekly R1","WMidpoint","Weekly PP","WMidpoint","Weekly S1","WMidpoint","Weekly S2","WMidpoint","Weekly S3");

var vLabelArrayM = new Array("Monthly R3","MMidpoint","Monthly R2","MMidpoint","Monthly R1","MMidpoint","Monthly PP","MMidpoint","Monthly S1","MMidpoint","Monthly S2","MMidpoint","Monthly S3");

 

//pivot line Colors in same order as labels above (e.g., R2=darkgreen, M4=blue, etc.)

var vColorArray = new Array( Color.yellow, Color.white, Color.yellow, Color.white, Color.yellow, Color.white, Color.yellow, Color.white, Color.yellow, Color.white, Color.yellow, Color.white, Color.yellow );

 

//pivot line types

var vTypeArray = new Array( "DASH", "DASHDOT", "DASH", "DASHDOT", "DASH", "DASHDOT", "SOLID", "DASHDOT", "DASH", "DASHDOT", "DASH", "DASHDOT", "DASH" );

 

//pivot line thicknesses

var vThickArray = new Array(1,1,1,1,1,1,3,1,1,1,1,1,1);

 

var vButLabels = new Array("", "Proj", "Gap1", "Gap2", "Reg", "(-)" );

var aFPArray = new Array();

var vInterval = null;

var vSymbol = null;

 

var nOffset = 2; //# of bars shifted to the right (from most current bar ) that you want to print the text

var nColor = Color.navy; //Color for the text labels

var sFont = "Arial"; //Font to use for the text

var nFontSize = 10; //Font size for the text.

var nPct = 100; //limit percentage

 

var bCursorLabels = false; //show all of the cursor labels in the data window??

var nMaxDays = 20; //# of days to display

var _nProject = null;

var _nLabels = null;

var _nGap = null;

var _nFlatLines = true;

var _nHLC = false;

var _nLimitPct = null;

var grID = 20;

 

var nCurHigh = 0;

var nCurLow = 0;

var nCurOpen = 0;

var nCurClose = 0;

var nTMP = 0; //today's in-progress Mid Point

var vToday = 0;

var vNow = null;

var vCalcInterval = "D";

var vTempDay = null;

 

var tdayO = 0; //today's open

var ydayO = 0; //yesterday's open

var ydayH = 0; //yesterday's high

var ydayL = 0; //yesterday's low

var ydayC = 0; //yesterday's close

var P = 0; //pivot

var MP = 0; //Midpoint

var W = 0; //Waist

var R1 = 0; //R1

var S1 = 0; //S1

var R2 = 0; //R2

var S2 = 0; //S2

var R3 = 0; //R3

var S3 = 0; //S3

 

var done = false;

var bInitialized = false;

 

function preMain() {

var x;

setPriceStudy(true);

setStudyTitle("TTM-Pivots (Daily)");

setShowTitleParameters(false);

 

for (x=0; x<vLabelArray.length; x++) {

setCursorLabelName(vLabelArray[x], x);

setDefaultBarStyle(eval( "PS_"+vTypeArray[x] ), x);

setDefaultBarFgColor(vColorArray[x], x);

setDefaultBarThickness(vThickArray[x], x);

}

 

 

 

 

setShowCursorLabel(bCursorLabels);

vLastSeenDay = null;

vOutputArray = null;

vResultArray = new Array();

 

//initialize formula parameters

x=0;

aFPArray[x] = new FunctionParameter( "frOpen", FunctionParameter.NUMBER);

with( aFPArray[x] ) {

setName( "Override Open" );

setLowerLimit(0);

setDefault(0);

}

x++;

aFPArray[x] = new FunctionParameter( "frHigh", FunctionParameter.NUMBER);

with( aFPArray[x] ) {

setName( "Override High" );

setLowerLimit(0);

setDefault(0);

}

x++;

aFPArray[x] = new FunctionParameter( "frLow", FunctionParameter.NUMBER);

with( aFPArray[x] ) {

setName( "Override Low" );

setLowerLimit(0);

setDefault(0);

}

x++;

aFPArray[x] = new FunctionParameter( "frClose", FunctionParameter.NUMBER);

with( aFPArray[x] ) {

setName( "Override Close" );

setLowerLimit(0);

setDefault(0);

}

x++;

aFPArray[x] = new FunctionParameter( "frMid", FunctionParameter.STRING);

with( aFPArray[x] ) {

setName( "Display MidPoints?" );

addOption( "T" );

addOption( "F" );

setDefault( "T" );

}

x++;

aFPArray[x] = new FunctionParameter( "frGap", FunctionParameter.STRING);

with( aFPArray[x] ) {

setName( "Apply Gap?" );

addOption( "T" );

addOption( "F" );

setDefault( "F" );

}

x++;

aFPArray[x] = new FunctionParameter( "frLabels", FunctionParameter.STRING);

with( aFPArray[x] ) {

setName( "Show Cursor Labels?" );

addOption("T");

addOption("F");

setDefault("T");

}

x++;

aFPArray[x] = new FunctionParameter( "frLabColor", FunctionParameter.COLOR);

with( aFPArray[x] ) {

setName( "Cursor Label Color" );

setDefault( Color.yellow );

}

x++;

aFPArray[x] = new FunctionParameter( "frDays", FunctionParameter.NUMBER);

with( aFPArray[x] ) {

setName( "Days to Display" );

setLowerLimit(1);

setUpperLimit(50);

setDefault(1);

}

x++;

aFPArray[x] = new FunctionParameter( "frInterval", FunctionParameter.STRING);

with( aFPArray[x] ) {

setName( "Pivot Type" );

addOption("Daily");

addOption("Weekly");

addOption("Monthly");

setDefault("Daily");

}

x++;

y=x;

for( z=0; z<vTitleArray.length; z++ ) {

aFPArray[y] = new FunctionParameter( "frColor"+(z+1), FunctionParameter.COLOR);

with( aFPArray[y] ) {

setName( vTitleArray[z] + " Color" );

setDefault( vColorArray[z] );

}

y++;

aFPArray[y] = new FunctionParameter( "frThick"+(z+1), FunctionParameter.NUMBER);

with( aFPArray[y] ) {

setName( vTitleArray[z] + " Thickness" );

setDefault( vThickArray[z] );

}

y++;

aFPArray[y] = new FunctionParameter( "frStyle"+(z+1), FunctionParameter.STRING);

with( aFPArray[y] ) {

setName( vTitleArray[z] + " Style" );

addOption( "SOLID" );

addOption( "DASH" );

addOption( "DASHDOT" );

addOption( "DASHDOTDOT" );

setDefault( vTypeArray[z] );

}

y++;

 

}

}

 

 

function main( frOpen, frHigh, frLow, frClose, frMid, frGap, frLabels, frLabColor, frDays, frInterval,

frColor1, frThick1, frStyle1, frColor2, frThick2, frStyle2, frColor3, frThick3,

frStyle3, frColor4, frThick4, frStyle4, frColor5, frThick5, frStyle5, frColor6,

frThick6, frStyle6, frColor7, frThick7, frStyle7, frColor8, frThick8, frStyle8,

frColor9, frThick9, frStyle9, frColor10, frThick10, frStyle10, frColor11, frThick11,

frStyle11, frColor12, frThick12, frStyle12, frColor13, frThick13, frStyle13 ) {

 

 

// initialize upon first loading formula

if(getBarState() == BARSTATE_ALLBARS) {

//get today's date stamp

vNow = new Date();

//get our bar interval

vInterval = getInterval();

//get our symbol

vSymbol = getSymbol().toUpperCase();

 

// for RTH, eg, to convert, ES Z2 to ES Z2=2

var rootSymbol = vSymbol.substring(0,3);

if (rootSymbol == "ES " || rootSymbol == "NQ ") {

if ( vSymbol.indexOf("=2") == -1 ) {

vSymbol += "=2";

}

}

 

return null;

}

 

// return null if not an intraday chart

if(vInterval == null || vInterval == "D" ||

vInterval == "W" || vInterval == "M" || vInterval == "T")

return null;

 

 

if ( bInitialized == false ) {

 

_nProject = 0;

_nLabels = frLabels == "T" ? 1 : 0;

_nGap = frGap=="T" ? 1 : 0;

_nFlatLines = true;

_nHLC = false;

_nLimitPct = 100.0;

nColor = frLabColor;

nMaxDays = Math.round( frDays );

vCalcInterval = frInterval[0];

 

for ( x=0; x<vLabelArray.length; x++ ) {

vColorArray[x] = eval( "frColor"+(x+1) );

vThickArray[x] = eval( "frThick"+(x+1) );

vTypeArray[x] = eval( "frStyle"+(x+1) );

}

 

for ( x=0; x<vLabelArray.length; x++ ) {

setDefaultBarStyle(eval( "PS_"+vTypeArray[x] ), x);

setDefaultBarFgColor(vColorArray[x], x);

setDefaultBarThickness(vThickArray[x], x);

}

 

 

//set plot type to flat lines if user selected this option

if (_nFlatLines==true) {

for (x=0; x<vLabelArray.length; x++) {

setPlotType(PLOTTYPE_FLATLINES, x);

}

}

 

 

vSymbol += ","+vCalcInterval;

 

//get the date stamp of the most recent bar

vTempDay = new Date( getValueAbsolute( "time", 0 ) );

 

//now move back by the number of days specified by the user, skipping weekends

for ( x=1; x<nMaxDays; x++ ) {

vTempDay.setDate( vTempDay.getDate()-1 );

if (vTempDay.getDay() == 6) {

vTempDay.setDate( vTempDay.getDate()-1 );

}

if (vTempDay.getDay() == 0) {

vTempDay.setDate( vTempDay.getDate()-2 );

}

}

 

//set the date/time stamp to the very beginning of the day

vTempDay.setHours( 0, 0, 0 );

 

bInitialized = true ;

}

 

 

// if first bar in new day, get and save yesterday's data

var vThisDay = null;

if ((vLastSeenDay != (vThisDay = getDay(0)) )) {

 

 

vToday = new Date( getValue( "time", 0 ) );

if ( vToday<vTempDay ) return;

 

var vTime = getValue( "rawtime", 0 );

if(vTime != null) {

 

if (_nProject != 0) {

 

//We don't project if interval is not daily

//if (vCalcInterval != "D") return;

 

if (vCalcInterval!="D") {

vTime = getValue("time", 0 );

vIndex = getWM( vTime, vCalcInterval);

}

//otherwise, get offset to correct daily bar

else {

var vIndex = getFirstBarIndexOfDay(vTime,vSymbol);

}

 

 

 

//we want to use today's data to project tomorrows

//pivot points so we have to draw the lines manually

//var vIndex = getFirstBarIndexOfDay(vTime,vSymbol);

if(vIndex != null) {

ydayO = frOpen>0 ? frOpen : getValueAbsolute("Open", vIndex, vSymbol);

ydayH = frHigh>0 ? frHigh : getValueAbsolute("High", vIndex, vSymbol);

ydayL = frLow>0 ? frLow : getValueAbsolute("Low", vIndex, vSymbol);

ydayC = frClose>0 ? frClose : getValueAbsolute("Close", vIndex, vSymbol);

//calcuate Pivot

P = (ydayH + ydayL + ydayC) / 3;

//calculate yesterday's Midpoint

MP = (ydayH + ydayL)/2;

//calculate yesterday's Waist

W = (ydayO + ydayC)/2;

//calculate the R/S variables

R1 = 2 * P - ydayL;

S1 = 2 * P - ydayH;

R2 = (P - S1) + R1;

S2 = P - (R1 - S1);

R3 = (P + R2) - S1;

S3 = (P - R2) + S1;

 

M6 = (R2+R3)/2;

M5 = (R2+R1)/2;

M4 = (R1+P)/2;

M3 = (S1+P)/2;

M2 = (S2+S1)/2;

M1 = (S2+S3)/2;

 

 

clearLines();

clearText();

 

if ( frMid=="T" )

vOutputArray = new Array (R3,M6,R2,M5,R1,M4,P,M3,S1,M2,S2,M1,S3)

else

vOutputArray = new Array (R3,null,R2,null,R1,null,P,null,S1,null,S2,null,S3);

 

drawLines( vOutputArray );

vLastSeenDay = vThisDay;

return null;

}

return null;

}

else {

 

//Get today's open in case we need it for gaps

vToday = getFirstBarIndexOfDay( vTime, vSymbol);

if (vToday != null) {

tdayO = getValueAbsolute("Open", vToday, vSymbol );

}

 

 

//we are using yesterday's data to build today's pivots so

//just return the values as an array to eSignal

if (vCalcInterval=="D") {

var vYDay = getPreviousTradingDay(vTime,vSymbol);

}

else {

vTime = getValue( "time", 0 );

var vYDay = vTime;

}

if(vYDay != null) {

//if not on daily bars, find offset to correct weekly or monthly bar

if (vCalcInterval!="D") {

vIndex = getWM( vTime, vCalcInterval);

}

//otherwise, get offset to correct daily bar

else {

var vIndex = getFirstBarIndexOfDay(vYDay,vSymbol);

}

 

if(vIndex != null) {

 

ydayO = frOpen>0 ? frOpen : getValueAbsolute("Open", vIndex, vSymbol);

ydayH = frHigh>0 ? frHigh : getValueAbsolute("High", vIndex, vSymbol);

ydayL = frLow>0 ? frLow : getValueAbsolute("Low", vIndex, vSymbol);

ydayC = frClose>0 ? frClose : getValueAbsolute("Close", vIndex, vSymbol);

//calcuate Pivot

P = (ydayH + ydayL + ydayC) / 3;

//calculate yesterday's Midpoint

MP = (ydayH + ydayL)/2;

//calculate yesterday's Waist

W = (ydayO + ydayC)/2;

//calculate the R/S variables

R1 = 2 * P - ydayL;

S1 = 2 * P - ydayH;

R2 = (P - S1) + R1;

S2 = P - (R1 - S1);

R3 = (P + R2) - S1;

S3 = (P - R2) + S1;

 

M6 = (R2+R3)/2;

M5 = (R2+R1)/2;

M4 = (R1+P)/2;

M3 = (S1+P)/2;

M2 = (S2+S1)/2;

M1 = (S2+S3)/2;

 

 

 

//display full or half gap... only if daily bars being used for pivot

if ((_nGap>0) && (vCalcInterval=="D")) {

if (_nGap==1){

vGap = (tdayO-ydayC);

setStudyTitle("TTM-Pivots (Daily w/Gap)");

}

P += vGap;

R1 += vGap;

S1 += vGap;

R2 += vGap;

S2 += vGap;

R3 += vGap;

S3 += vGap;

M6 += vGap;

M5 += vGap;

M4 += vGap;

M3 += vGap;

M2 += vGap;

M1 += vGap;

}

 

if (vCalcInterval=="W") {

setStudyTitle("TTM-Pivots (Weekly)");

}

else if (vCalcInterval=="M") {

setStudyTitle("TTM-Pivots (Monthly)");

}

 

if ( frMid=="T" )

vOutputArray = new Array (R3,M6,R2,M5,R1,M4,P,M3,S1,M2,S2,M1,S3)

else

vOutputArray = new Array (R3,null,R2,null,R1,null,P,null,S1,null,S2,null,S3);

 

vResultArray = reduceLines( vOutputArray, _nLimitPct, close() );

 

 

if (_nLabels==1)

drawLabels( vResultArray );

 

vLastSeenDay = vThisDay;

return vResultArray;

}

}

return null;

}

}

}

// else just return the saved data

else {

if (_nProject==0) {

vResultArray = reduceLines( vOutputArray, _nLimitPct, close() );

if (_nLabels==1)

drawLabels( vResultArray );

return vResultArray;

}

}

 

}

 

 

 

//== Convert array elements to null if they are more than x% away from

//== the current price (reduces the nnumber of lines drawn on the screen)

 

function reduceLines( aArray, nCt, nPrice ) {

var x;

var xPct;

var xTmp;

var aReturn;

 

if (aArray==null) return;

 

xPct = nCt/100;

 

 

for (x=0; x<aArray.length; x++) {

if (aArray[x] != null) {

xTmp = Math.abs((aArray[x] - nPrice) / nPrice);

if (xTmp > xPct) {

aArray[x] = null;

}

}

}

 

aReturn = new Array();

for (x=0; x<aArray.length; x++) {

aReturn[x] = aArray[x];

}

 

return( aReturn );

 

}

 

 

 

//== Find the correct weekly or monthly bar based upon

//== the date passed to this function

function getWM( xTime, xInterval ) {

var x;

var c = xTime.getTime();

var d1;

var d2;

 

//Weekly and Monthly bars are date stamped with the last bar of week or month and

//time stamped at 00:00 hours which would be the morning of that day. To facilitate

//a comparison check, I add 1-day minus 1 millisecond to the value.

 

x = 0;

while( true ) {

d1 = getValueAbsolute("Time", -x, getSymbol()+","+xInterval ).getTime()+86399999;

d2 = getValueAbsolute("Time", -(x+1), getSymbol()+","+xInterval ).getTime()+86399999;

if ((d2==null) || (d1==null)) return( null );

if ((c>d2) && (c<=d1)) {

//we want the prior week or month so add 1 to the index

return( -(x+1) );

}

x++;

}

 

return( null );

 

}

 

 

//== gID function assigns unique identifier to graphic/text routines

function gID() {

grID++;

return( grID );

}

 

//== draw text labels for the s/r levels

function drawLabels( dataArray ) {

var x;

var sTmp;

var sPrice;

var xFlags;

 

if ( dataArray==null ) return;

 

//this prevents the labels from printing a gazillion times

//as the chart is being built. Speeds up processing

if (getCurrentBarIndex() != -1) return;

 

//cycle through the output array and add the corresponding prefix

//from the static label array

for (x=0; x<dataArray.length; x++) {

if (vCalcInterval=="D") sTmp = vLabelArray[x]+"=";

if (vCalcInterval=="W") sTmp = vLabelArrayW[x]+"=";

if (vCalcInterval=="M") sTmp = vLabelArrayM[x]+"=";

 

if ( dataArray[x] != null ) {

if (getBuildNumber() >= 564) {

sPrice = formatPriceNumber( dataArray[x] );

xFlags = Text.VCENTER | Text.BOLD | Text.ONTOP;

}

else {

sPrice = rnd( dataArray[x], 2 );

xFlags = Text.BOLD | Text.BOTTOM | Text.ONTOP;

}

 

drawTextAbsolute(nOffset, dataArray[x], sTmp+sPrice, nColor, null, xFlags , sFont, nFontSize, gID());

}

}

return;

}

 

 

//== rnd will round to N digits.

function rnd(value, N) {

var n;

var mult=1;

for(n=0;n<N;n++) mult*=10;

value*=mult;

return Math.round( value,N)/mult;

}

Share this post


Link to post
Share on other sites
These code are for esignal pivots. If someone can convert in tradestation it's arrange all the problem that indicator have.

 

philloo

 

 

 

Fix History:

 

02/02/2005 - Initial Release

1.0.0

 

=====================================================================

Project Description:

 

 

Dislaimer: For educational purposes only! Obviously, no guarantees

whatsoever and use at your own risk.

 

**********************************************************************/

 

// globals

var vOutputArray = null;

var vResultArray = null;

var vLastSeenDay = null;

 

//pivot line labels ( Daily, Weekly and Monthly)

var vTitleArray = new Array("R3", "M6", "R2", "M5", "R1", "M4", "PP", "M3", "S1", "M2", "S2", "M1", "S3");

var vLabelArray = new Array("Daily R3","Midpoint","Daily R2","Midpoint","Daily R1","Midpoint","Daily PP","Midpoint","Daily S1","Midpoint","Daily S2","Midpoint","Daily S3");

var vLabelArrayW = new Array("Weekly R3","WMidpoint","Weekly R2","WMidpoint","Weekly R1","WMidpoint","Weekly PP","WMidpoint","Weekly S1","WMidpoint","Weekly S2","WMidpoint","Weekly S3");

var vLabelArrayM = new Array("Monthly R3","MMidpoint","Monthly R2","MMidpoint","Monthly R1","MMidpoint","Monthly PP","MMidpoint","Monthly S1","MMidpoint","Monthly S2","MMidpoint","Monthly S3");

 

//pivot line Colors in same order as labels above (e.g., R2=darkgreen, M4=blue, etc.)

var vColorArray = new Array( Color.yellow, Color.white, Color.yellow, Color.white, Color.yellow, Color.white, Color.yellow, Color.white, Color.yellow, Color.white, Color.yellow, Color.white, Color.yellow );

 

//pivot line types

var vTypeArray = new Array( "DASH", "DASHDOT", "DASH", "DASHDOT", "DASH", "DASHDOT", "SOLID", "DASHDOT", "DASH", "DASHDOT", "DASH", "DASHDOT", "DASH" );

 

//pivot line thicknesses

var vThickArray = new Array(1,1,1,1,1,1,3,1,1,1,1,1,1);

 

var vButLabels = new Array("", "Proj", "Gap1", "Gap2", "Reg", "(-)" );

var aFPArray = new Array();

var vInterval = null;

var vSymbol = null;

 

var nOffset = 2; //# of bars shifted to the right (from most current bar ) that you want to print the text

var nColor = Color.navy; //Color for the text labels

var sFont = "Arial"; //Font to use for the text

var nFontSize = 10; //Font size for the text.

var nPct = 100; //limit percentage

 

var bCursorLabels = false; //show all of the cursor labels in the data window??

var nMaxDays = 20; //# of days to display

var _nProject = null;

var _nLabels = null;

var _nGap = null;

var _nFlatLines = true;

var _nHLC = false;

var _nLimitPct = null;

var grID = 20;

 

var nCurHigh = 0;

var nCurLow = 0;

var nCurOpen = 0;

var nCurClose = 0;

var nTMP = 0; //today's in-progress Mid Point

var vToday = 0;

var vNow = null;

var vCalcInterval = "D";

var vTempDay = null;

 

var tdayO = 0; //today's open

var ydayO = 0; //yesterday's open

var ydayH = 0; //yesterday's high

var ydayL = 0; //yesterday's low

var ydayC = 0; //yesterday's close

var P = 0; //pivot

var MP = 0; //Midpoint

var W = 0; //Waist

var R1 = 0; //R1

var S1 = 0; //S1

var R2 = 0; //R2

var S2 = 0; //S2

var R3 = 0; //R3

var S3 = 0; //S3

 

var done = false;

var bInitialized = false;

 

function preMain() {

var x;

setPriceStudy(true);

setStudyTitle("TTM-Pivots (Daily)");

setShowTitleParameters(false);

 

for (x=0; x<vLabelArray.length; x++) {

setCursorLabelName(vLabelArray[x], x);

setDefaultBarStyle(eval( "PS_"+vTypeArray[x] ), x);

setDefaultBarFgColor(vColorArray[x], x);

setDefaultBarThickness(vThickArray[x], x);

}

 

 

 

 

setShowCursorLabel(bCursorLabels);

vLastSeenDay = null;

vOutputArray = null;

vResultArray = new Array();

 

//initialize formula parameters

x=0;

aFPArray[x] = new FunctionParameter( "frOpen", FunctionParameter.NUMBER);

with( aFPArray[x] ) {

setName( "Override Open" );

setLowerLimit(0);

setDefault(0);

}

x++;

aFPArray[x] = new FunctionParameter( "frHigh", FunctionParameter.NUMBER);

with( aFPArray[x] ) {

setName( "Override High" );

setLowerLimit(0);

setDefault(0);

}

x++;

aFPArray[x] = new FunctionParameter( "frLow", FunctionParameter.NUMBER);

with( aFPArray[x] ) {

setName( "Override Low" );

setLowerLimit(0);

setDefault(0);

}

x++;

aFPArray[x] = new FunctionParameter( "frClose", FunctionParameter.NUMBER);

with( aFPArray[x] ) {

setName( "Override Close" );

setLowerLimit(0);

setDefault(0);

}

x++;

aFPArray[x] = new FunctionParameter( "frMid", FunctionParameter.STRING);

with( aFPArray[x] ) {

setName( "Display MidPoints?" );

addOption( "T" );

addOption( "F" );

setDefault( "T" );

}

x++;

aFPArray[x] = new FunctionParameter( "frGap", FunctionParameter.STRING);

with( aFPArray[x] ) {

setName( "Apply Gap?" );

addOption( "T" );

addOption( "F" );

setDefault( "F" );

}

x++;

aFPArray[x] = new FunctionParameter( "frLabels", FunctionParameter.STRING);

with( aFPArray[x] ) {

setName( "Show Cursor Labels?" );

addOption("T");

addOption("F");

setDefault("T");

}

x++;

aFPArray[x] = new FunctionParameter( "frLabColor", FunctionParameter.COLOR);

with( aFPArray[x] ) {

setName( "Cursor Label Color" );

setDefault( Color.yellow );

}

x++;

aFPArray[x] = new FunctionParameter( "frDays", FunctionParameter.NUMBER);

with( aFPArray[x] ) {

setName( "Days to Display" );

setLowerLimit(1);

setUpperLimit(50);

setDefault(1);

}

x++;

aFPArray[x] = new FunctionParameter( "frInterval", FunctionParameter.STRING);

with( aFPArray[x] ) {

setName( "Pivot Type" );

addOption("Daily");

addOption("Weekly");

addOption("Monthly");

setDefault("Daily");

}

x++;

y=x;

for( z=0; z<vTitleArray.length; z++ ) {

aFPArray[y] = new FunctionParameter( "frColor"+(z+1), FunctionParameter.COLOR);

with( aFPArray[y] ) {

setName( vTitleArray[z] + " Color" );

setDefault( vColorArray[z] );

}

y++;

aFPArray[y] = new FunctionParameter( "frThick"+(z+1), FunctionParameter.NUMBER);

with( aFPArray[y] ) {

setName( vTitleArray[z] + " Thickness" );

setDefault( vThickArray[z] );

}

y++;

aFPArray[y] = new FunctionParameter( "frStyle"+(z+1), FunctionParameter.STRING);

with( aFPArray[y] ) {

setName( vTitleArray[z] + " Style" );

addOption( "SOLID" );

addOption( "DASH" );

addOption( "DASHDOT" );

addOption( "DASHDOTDOT" );

setDefault( vTypeArray[z] );

}

y++;

 

}

}

 

 

function main( frOpen, frHigh, frLow, frClose, frMid, frGap, frLabels, frLabColor, frDays, frInterval,

frColor1, frThick1, frStyle1, frColor2, frThick2, frStyle2, frColor3, frThick3,

frStyle3, frColor4, frThick4, frStyle4, frColor5, frThick5, frStyle5, frColor6,

frThick6, frStyle6, frColor7, frThick7, frStyle7, frColor8, frThick8, frStyle8,

frColor9, frThick9, frStyle9, frColor10, frThick10, frStyle10, frColor11, frThick11,

frStyle11, frColor12, frThick12, frStyle12, frColor13, frThick13, frStyle13 ) {

 

 

// initialize upon first loading formula

if(getBarState() == BARSTATE_ALLBARS) {

//get today's date stamp

vNow = new Date();

//get our bar interval

vInterval = getInterval();

//get our symbol

vSymbol = getSymbol().toUpperCase();

 

// for RTH, eg, to convert, ES Z2 to ES Z2=2

var rootSymbol = vSymbol.substring(0,3);

if (rootSymbol == "ES " || rootSymbol == "NQ ") {

if ( vSymbol.indexOf("=2") == -1 ) {

vSymbol += "=2";

}

}

 

return null;

}

 

// return null if not an intraday chart

if(vInterval == null || vInterval == "D" ||

vInterval == "W" || vInterval == "M" || vInterval == "T")

return null;

 

 

if ( bInitialized == false ) {

 

_nProject = 0;

_nLabels = frLabels == "T" ? 1 : 0;

_nGap = frGap=="T" ? 1 : 0;

_nFlatLines = true;

_nHLC = false;

_nLimitPct = 100.0;

nColor = frLabColor;

nMaxDays = Math.round( frDays );

vCalcInterval = frInterval[0];

 

for ( x=0; x<vLabelArray.length; x++ ) {

vColorArray[x] = eval( "frColor"+(x+1) );

vThickArray[x] = eval( "frThick"+(x+1) );

vTypeArray[x] = eval( "frStyle"+(x+1) );

}

 

for ( x=0; x<vLabelArray.length; x++ ) {

setDefaultBarStyle(eval( "PS_"+vTypeArray[x] ), x);

setDefaultBarFgColor(vColorArray[x], x);

setDefaultBarThickness(vThickArray[x], x);

}

 

 

//set plot type to flat lines if user selected this option

if (_nFlatLines==true) {

for (x=0; x<vLabelArray.length; x++) {

setPlotType(PLOTTYPE_FLATLINES, x);

}

}

 

 

vSymbol += ","+vCalcInterval;

 

//get the date stamp of the most recent bar

vTempDay = new Date( getValueAbsolute( "time", 0 ) );

 

//now move back by the number of days specified by the user, skipping weekends

for ( x=1; x<nMaxDays; x++ ) {

vTempDay.setDate( vTempDay.getDate()-1 );

if (vTempDay.getDay() == 6) {

vTempDay.setDate( vTempDay.getDate()-1 );

}

if (vTempDay.getDay() == 0) {

vTempDay.setDate( vTempDay.getDate()-2 );

}

}

 

//set the date/time stamp to the very beginning of the day

vTempDay.setHours( 0, 0, 0 );

 

bInitialized = true ;

}

 

 

// if first bar in new day, get and save yesterday's data

var vThisDay = null;

if ((vLastSeenDay != (vThisDay = getDay(0)) )) {

 

 

vToday = new Date( getValue( "time", 0 ) );

if ( vToday<vTempDay ) return;

 

var vTime = getValue( "rawtime", 0 );

if(vTime != null) {

 

if (_nProject != 0) {

 

//We don't project if interval is not daily

//if (vCalcInterval != "D") return;

 

if (vCalcInterval!="D") {

vTime = getValue("time", 0 );

vIndex = getWM( vTime, vCalcInterval);

}

//otherwise, get offset to correct daily bar

else {

var vIndex = getFirstBarIndexOfDay(vTime,vSymbol);

}

 

 

 

//we want to use today's data to project tomorrows

//pivot points so we have to draw the lines manually

//var vIndex = getFirstBarIndexOfDay(vTime,vSymbol);

if(vIndex != null) {

ydayO = frOpen>0 ? frOpen : getValueAbsolute("Open", vIndex, vSymbol);

ydayH = frHigh>0 ? frHigh : getValueAbsolute("High", vIndex, vSymbol);

ydayL = frLow>0 ? frLow : getValueAbsolute("Low", vIndex, vSymbol);

ydayC = frClose>0 ? frClose : getValueAbsolute("Close", vIndex, vSymbol);

//calcuate Pivot

P = (ydayH + ydayL + ydayC) / 3;

//calculate yesterday's Midpoint

MP = (ydayH + ydayL)/2;

//calculate yesterday's Waist

W = (ydayO + ydayC)/2;

//calculate the R/S variables

R1 = 2 * P - ydayL;

S1 = 2 * P - ydayH;

R2 = (P - S1) + R1;

S2 = P - (R1 - S1);

R3 = (P + R2) - S1;

S3 = (P - R2) + S1;

 

M6 = (R2+R3)/2;

M5 = (R2+R1)/2;

M4 = (R1+P)/2;

M3 = (S1+P)/2;

M2 = (S2+S1)/2;

M1 = (S2+S3)/2;

 

 

clearLines();

clearText();

 

if ( frMid=="T" )

vOutputArray = new Array (R3,M6,R2,M5,R1,M4,P,M3,S1,M2,S2,M1,S3)

else

vOutputArray = new Array (R3,null,R2,null,R1,null,P,null,S1,null,S2,null,S3);

 

drawLines( vOutputArray );

vLastSeenDay = vThisDay;

return null;

}

return null;

}

else {

 

//Get today's open in case we need it for gaps

vToday = getFirstBarIndexOfDay( vTime, vSymbol);

if (vToday != null) {

tdayO = getValueAbsolute("Open", vToday, vSymbol );

}

 

 

//we are using yesterday's data to build today's pivots so

//just return the values as an array to eSignal

if (vCalcInterval=="D") {

var vYDay = getPreviousTradingDay(vTime,vSymbol);

}

else {

vTime = getValue( "time", 0 );

var vYDay = vTime;

}

if(vYDay != null) {

//if not on daily bars, find offset to correct weekly or monthly bar

if (vCalcInterval!="D") {

vIndex = getWM( vTime, vCalcInterval);

}

//otherwise, get offset to correct daily bar

else {

var vIndex = getFirstBarIndexOfDay(vYDay,vSymbol);

}

 

if(vIndex != null) {

 

ydayO = frOpen>0 ? frOpen : getValueAbsolute("Open", vIndex, vSymbol);

ydayH = frHigh>0 ? frHigh : getValueAbsolute("High", vIndex, vSymbol);

ydayL = frLow>0 ? frLow : getValueAbsolute("Low", vIndex, vSymbol);

ydayC = frClose>0 ? frClose : getValueAbsolute("Close", vIndex, vSymbol);

//calcuate Pivot

P = (ydayH + ydayL + ydayC) / 3;

//calculate yesterday's Midpoint

MP = (ydayH + ydayL)/2;

//calculate yesterday's Waist

W = (ydayO + ydayC)/2;

//calculate the R/S variables

R1 = 2 * P - ydayL;

S1 = 2 * P - ydayH;

R2 = (P - S1) + R1;

S2 = P - (R1 - S1);

R3 = (P + R2) - S1;

S3 = (P - R2) + S1;

 

M6 = (R2+R3)/2;

M5 = (R2+R1)/2;

M4 = (R1+P)/2;

M3 = (S1+P)/2;

M2 = (S2+S1)/2;

M1 = (S2+S3)/2;

 

 

 

//display full or half gap... only if daily bars being used for pivot

if ((_nGap>0) && (vCalcInterval=="D")) {

if (_nGap==1){

vGap = (tdayO-ydayC);

setStudyTitle("TTM-Pivots (Daily w/Gap)");

}

P += vGap;

R1 += vGap;

S1 += vGap;

R2 += vGap;

S2 += vGap;

R3 += vGap;

S3 += vGap;

M6 += vGap;

M5 += vGap;

M4 += vGap;

M3 += vGap;

M2 += vGap;

M1 += vGap;

}

 

if (vCalcInterval=="W") {

setStudyTitle("TTM-Pivots (Weekly)");

}

else if (vCalcInterval=="M") {

setStudyTitle("TTM-Pivots (Monthly)");

}

 

if ( frMid=="T" )

vOutputArray = new Array (R3,M6,R2,M5,R1,M4,P,M3,S1,M2,S2,M1,S3)

else

vOutputArray = new Array (R3,null,R2,null,R1,null,P,null,S1,null,S2,null,S3);

 

vResultArray = reduceLines( vOutputArray, _nLimitPct, close() );

 

 

if (_nLabels==1)

drawLabels( vResultArray );

 

vLastSeenDay = vThisDay;

return vResultArray;

}

}

return null;

}

}

}

// else just return the saved data

else {

if (_nProject==0) {

vResultArray = reduceLines( vOutputArray, _nLimitPct, close() );

if (_nLabels==1)

drawLabels( vResultArray );

return vResultArray;

}

}

 

}

 

 

 

//== Convert array elements to null if they are more than x% away from

//== the current price (reduces the nnumber of lines drawn on the screen)

 

function reduceLines( aArray, nCt, nPrice ) {

var x;

var xPct;

var xTmp;

var aReturn;

 

if (aArray==null) return;

 

xPct = nCt/100;

 

 

for (x=0; x<aArray.length; x++) {

if (aArray[x] != null) {

xTmp = Math.abs((aArray[x] - nPrice) / nPrice);

if (xTmp > xPct) {

aArray[x] = null;

}

}

}

 

aReturn = new Array();

for (x=0; x<aArray.length; x++) {

aReturn[x] = aArray[x];

}

 

return( aReturn );

 

}

 

 

 

//== Find the correct weekly or monthly bar based upon

//== the date passed to this function

function getWM( xTime, xInterval ) {

var x;

var c = xTime.getTime();

var d1;

var d2;

 

//Weekly and Monthly bars are date stamped with the last bar of week or month and

//time stamped at 00:00 hours which would be the morning of that day. To facilitate

//a comparison check, I add 1-day minus 1 millisecond to the value.

 

x = 0;

while( true ) {

d1 = getValueAbsolute("Time", -x, getSymbol()+","+xInterval ).getTime()+86399999;

d2 = getValueAbsolute("Time", -(x+1), getSymbol()+","+xInterval ).getTime()+86399999;

if ((d2==null) || (d1==null)) return( null );

if ((c>d2) && (c<=d1)) {

//we want the prior week or month so add 1 to the index

return( -(x+1) );

}

x++;

}

 

return( null );

 

}

 

 

//== gID function assigns unique identifier to graphic/text routines

function gID() {

grID++;

return( grID );

}

 

//== draw text labels for the s/r levels

function drawLabels( dataArray ) {

var x;

var sTmp;

var sPrice;

var xFlags;

 

if ( dataArray==null ) return;

 

//this prevents the labels from printing a gazillion times

//as the chart is being built. Speeds up processing

if (getCurrentBarIndex() != -1) return;

 

//cycle through the output array and add the corresponding prefix

//from the static label array

for (x=0; x<dataArray.length; x++) {

if (vCalcInterval=="D") sTmp = vLabelArray[x]+"=";

if (vCalcInterval=="W") sTmp = vLabelArrayW[x]+"=";

if (vCalcInterval=="M") sTmp = vLabelArrayM[x]+"=";

 

if ( dataArray[x] != null ) {

if (getBuildNumber() >= 564) {

sPrice = formatPriceNumber( dataArray[x] );

xFlags = Text.VCENTER | Text.BOLD | Text.ONTOP;

}

else {

sPrice = rnd( dataArray[x], 2 );

xFlags = Text.BOLD | Text.BOTTOM | Text.ONTOP;

}

 

drawTextAbsolute(nOffset, dataArray[x], sTmp+sPrice, nColor, null, xFlags , sFont, nFontSize, gID());

}

}

return;

}

 

 

//== rnd will round to N digits.

function rnd(value, N) {

var n;

var mult=1;

for(n=0;n<N;n++) mult*=10;

value*=mult;

return Math.round( value,N)/mult;

}

I don't mention that the code are for the daliy pivots.

Share this post


Link to post
Share on other sites

Question -I downloaded these pivots and I love them. One problem. The labels on the pivots keep on dissapearing on my chart. Is there a way to make them stay on my chart? I appreciate the help.

 

TJ

Share this post


Link to post
Share on other sites
Question -I downloaded these pivots and I love them. One problem. The labels on the pivots keep on dissapearing on my chart. Is there a way to make them stay on my chart? I appreciate the help.

 

TJ

 

Yep...look back about 5 posts. ;)

Share this post


Link to post
Share on other sites

Hey Gang,

 

Another sily questions. I got the labels to stick on a 5 minute chart but cannot get them to stay on a tick chart. Does anyone know how to get the labels to show on a tick chart? I appreciate it

 

TJ

Share this post


Link to post
Share on other sites

Hi all. My first post (newbie). I love the site and cant express how appreciative I am for all the effort and support in this site. I have been experimenting with pivots a lot and in recent times the volatility has surpassed the s3 and r3 zones. I am new to programming in tradestation and would like to see if anyone could possibly update the "soultrader pivot point" to include a s4 and r4 for daily levels. I am playing with the code a little but am unsuccessful of late. Take care all and happy trading. :)

Share this post


Link to post
Share on other sites
Hi all. My first post (newbie). I love the site and cant express how appreciative I am for all the effort and support in this site. I have been experimenting with pivots a lot and in recent times the volatility has surpassed the s3 and r3 zones. I am new to programming in tradestation and would like to see if anyone could possibly update the "soultrader pivot point" to include a s4 and r4 for daily levels. I am playing with the code a little but am unsuccessful of late. Take care all and happy trading. :)

 

Couuple of things you could addd/subtract half the range to S3 R3. I also notice the description appears a bit off. The range I believe is asymmetric for calculating S/R. I would guess the code is actually correct thoug havent checked.

Share this post


Link to post
Share on other sites

Hi there

 

Im having problems with this indicator, when I click on the paintbar, I get nothing. Can someone please help me in getting this to work with GOOGLE (maybe yesterday day). If you can please printscreen the input box for GOOGLE that would be very kind of you.

 

Kind regards

Edited by theman

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Topics

  • Posts

    • $ARRY Array Technologies stock great day off the 10.96 double support area, from Stocks To Watch, https://stockconsultant.com/?ARRY
    • $MSFT Microsoft stock back up top of the range, breakout watch , https://stockconsultant.com/?MSFT
    • GBTC Grayscale Bitcoin stock top of range breakout watch , https://stockconsultant.com/?GBTC
    • $FSLR First Solar stock nice bull flag breakout, from Stocks To Watch, https://stockconsultant.com/?FSLR
    • Date: 22nd May 2024. UK Inflation Drop Boosts GBP, But Analysts See Correction Signals. The NASDAQ forms its 5th bullish wave resulting in the index trading 8% higher this month alone. Investors are waiting for NVIDIA’s earnings report. The market awaits the release of the latest FOMC Meeting Minutes for further indications on the potential rate adjustments. The US Dollar Index declines to a 7-week low, but can tonight’s Meeting Minutes change the trend? Read below what economists are predicting. UK inflation declines from 3.2% to 2.3% in its largest drop since December 2023. The Pound increases as the inflation rate did not decline to 2.1% as previously GBPUSD – UK Inflation Drops But Does Not Meet Previous Expectations! The GBPUSD is trading 0.30% higher after the release of April’s UK inflation figures. The US Dollar and the Japanese Yen are the worst performing currencies of the day. Traders looking to speculate a rising Pound may benefit from these weakening currencies. The GBPJPY is trading 0.47% higher so far. However, investors should be cautious of any change in price action as the next session (European Market) opens. The UK’s inflation figure fell from 3.2% to 2.3% which is the largest drop in 2024 so far and brings the Bank of England closer to its target. This would normally pressure the currency, but there are some factors which have triggered a bullish Pound. This includes the Core Consumer Price Index which fell from 4.2% to 3.9% instead of falling to 3.6% which were the previous expectations. Also, certain sectors did not see a decline in inflation in April, which is a continued concern. For these reasons, investors have increased their exposure to the Pound, supporting the currency. Also, economists are advising that the weakening inflation rate can increase investment demand which also further supports the country’s economy and subsequently the currency. Furthermore, investors will also need to take into consideration the price condition of the US Dollar individually. Dollar traders will be focusing on tonight’s Federal Open Market Committee’s Meeting Minutes. The market will particularly be looking for clarity on how many adjustments are likely in 2024, if any at all. In addition to this, if an adjustment is likely in July, September or later in the year. If the report indicates less cuts and a delay, the US Dollar potentially can witness further demand and a change in trend. This is something which was particularly seen in April 2024. The price action of the GBPUSD is forming a bullish trend and most trend-based indicators are signalling a higher price. However, there are signs that the price may correct back to the previous range. For example, on the 4-Hour chart the price is witnessing a divergence signal. in addition to this, the price is also trading at a significant resistance level from November, December and January. Though, for the resistance level to become active, the Dollar will likely require support from the upcoming Meeting Minutes. In the short term, sell signals are likely to materialize after crossing 1.27400 and 1.27268.   USA100 – Bullish Trend, But Investor Focus On Meeting Minutes & NVIDIA Earnings The NASDAQ saw a decline in the price as the US Open was approaching, however, the price momentum quickly changed when US investors started trading. The index rose 0.30% by the end of day and was the best performing US index. During the US Session 62.5% of stocks holding a weight of more than 1.00% rose while 37.5% fell. The main price drivers which supported the upward price movement were Microsoft, Alphabet, Apple, NVIDIA and Netflix. Investors will closely be monitoring the upcoming earnings report for NVIDIA, but also the FOMC’s Meeting Minutes. A more restrictive monetary policy can pressure the stock market, but the level of pressure and downward price movement will also depend on the results of NVIDIA’s earnings. Additionally, shareholders will also focus on Intuit’s Quarterly Earnings Report tomorrow evening, but this will have a lesser effect compared to NVIDIA. A concern for intraday traders is the decline in indices around the world in markets which are currently open. For example, the DAX, FTSE100, CAC and Nikkei225 are all trading lower. In addition to this, the US 10-Year Bond Yields are trading 0.0027% higher which is additional pressure on equities. Nonetheless, technical analysis in the medium to longer term continue to point to a continued upward trend. Always trade with strict risk management. Your capital is the single most important aspect of your trading business. Please note that times displayed based on local time zone and are from time of writing this report. Click HERE to access the full HFM Economic calendar. Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding on how markets work. Click HERE to register for FREE! Click HERE to READ more Market news. Michalis Efthymiou Market Analyst HFMarkets Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in FX and CFDs products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.