npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@mediaplatform/sportal365-tennis-sdk

v1.2.13

Published

### Installation

Downloads

250

Readme

JavaScript Tennis SDK

Installation

Install Tennis SDK dependency

npm install @mediaplatform/sportal365-tennis-sdk --save

or

yarn add @mediaplatform/sportal365-tennis-sdk

Usage

Import Tennis SDK dependency

import Core from "@mediaplatform/sportal365-tennis-sdk"

Initialize Tennis SDK

const SDK = new Core(config);

The config argument is an object with the following properties:

  • dataConfigApiUrl - API URL (required)
  • dataConfigApiKey - API KEY (required)
  • dataConfigPlayoffApiUrl - API url for playoff data (required if you want to use .playoff module)
  • dataConfigStandingsApiUrl - API url for ranking data (required if you want to use .ranking module)
  • dataConfigLang - example: 'en'
  • dataConfigProject - Project name (required)
  • dataConfigOddClient - default value: 'sportal' (optional)
  • dataConfigTimezone - example: 'Europe/Sofia' (required)
  • dataConfigCompetitionList - example: 'default' (required)

Match Module

Initialize module

const matchModule = SDK.match(matchId);

matchId - the argument is required (matchId: string). It defines the required match.

Usage

matchModule
  .withOdds({ bettingId: 'string', market: 'string', oddFormat: 'string', preEventOddsOnly: 'boolean' })
  .get();

Corresponding output should be:

{
 	 match: MatchModel
};

Module methods

  • withOdds({ bettingId: string, market: string, oddFormat: string, preEventOddsOnly: boolean })

    • bettingId - the argument is a string. If no bettingId is provided, the result will be filtered by the first provider from the response.
    • market - the argument is a string. Example: "1x2"- will return only "1x2" markets data (if there is one).
    • oddFormat - the argument is a string ( FRACTIONAL, DECIMAL, MONEYLINE ). Default value: "DECIMAL". You could pass an odds format to format odds values.
    • preEventOddsOnly - the argument is a boolean which shows odds only when the match has not started yet. The default value of the argument is false.
  • get() - the method is mandatory - Based on called methods, it returns the built object with all requested information for the match and filtered odds by the given providers id, markets and formated odds values.

Matches Module

Initialize module

const matchesModule = SDK.matches({
	competitionIds: string[];
	seasonIds: string[];
	tournamentIds: string[];
	sortDirection: string;
	limit: string;
	roundFilter: [ {roundId: string, tournamentId: string } ];
});

Usage 1

matchesModule
  .groupMatchesByTournament()
  .withDateConfig({ date: 'string'} )
  .withStatusFilter({ statusType: 'string', competitionList: 'string' })
  .withType(type: 'string')
  .withGender(gender: 'string')
  .withOdds({ bettingId: 'string', market: 'string', oddFormat: 'string', showWithOddsOnly: boolean, preEventOddsOnly: 'boolean' })
  .get();

Corresponding output should be:

{
  matches: [{
	 tournament: TournamentModel,
	 matches: [{ match: MatchModel  }]
	}]
};

Module methods

  • competitionIds(string[]) - (optional) Use this method to filter by competition.

  • seasonIds(string[]) - (optional) Use this method to filter by season.

  • tournamentIds(string[]) - (optional) Use this method to filter by tournaments.

  • roundFilter([ {roundId: string, tournamentId: string} ]) - (optional) Use this method to filter by roundIds.

  • limit(string) - (optional) Use this method to limit the number of matches.

  • sortDirection(string) - (optional) Use this method to set the direction in which the programme matches are sorted - 'asc'/'desc'.

  • groupMatchesByTournament() - Use this method to group the matches by tournament.

  • withStatusFilter({statusType: string, competitionList?: string}) - Use this method to get matches by specific statusType.

    • statusType - The argument should be a string ( 'LIVE', 'UPCOMING', 'FINISHED', 'INTERRUPTED', 'CANCELLED', 'POSTPONED', 'POPULAR' )
    • competitionList - The argument is an optional string that should be used in conjunction with the statusType argument when statusType is set to 'POPULAR'. Note that it overrides the dataConfigCompetitionList supplied to the SDK's Core.
  • withType(type: string) - Use this method to get matches by specific type.

    • type -The argument should be a string ( 'SINGLE', 'DOUBLE', 'TEAM' )
  • withGender(gender: string) - Use this method to get matches by specific gender.

    • gender -The argument should be a string ( 'MALE', 'FEMALE', 'MIXED' )
  • withDateConfig({ date: string, dateFormat: string }) - Use this method to format the date by specific dateFormat.

    • date -The argument should be a string('yyyy.MM.dd'). Use this method to get matches from specific start date.
    • dateFormat - Default value "dd.MM".
  • withOdds({ bettingId: string, market: string, oddFormat: string, showWithOddsOnly: boolean, preEventOddsOnly: boolean })

    • bettingId - the argument is a string. If no bettingId is provided, the result will be filtered by the first provider from the response.
    • market - the argument is a string. Example: "1x2"- will return only "1x2" markets data (if there is one).
    • oddFormat - the argument is a string ( FRACTIONAL, DECIMAL, MONEYLINE ). Default value: "DECIMAL". You could pass an odds format to format odds values.
    • showWithOddsOnly - the argument is a boolean ( true / false ). You could pass a showWithOddsOnly to filter matches with odds values.
    • preEventOddsOnly - the argument is a boolean which shows odds only when the match has not started yet. The default value of the argument is false.

Usage 2

matchesModule
  .withDateConfig({ date: 'string', dateFormat: 'string'} )
  .withStatusFilter({ statusType: 'string', competitionList: 'string' })
  .withType(type: 'string')
  .withGender(gender: 'string')
  .withOdds({ bettingId: 'string', market: 'string', oddFormat: 'string', preEventOddsOnly: 'boolean' })
  .get();

Corresponding output should be:

{
  matches: [
		{ match: MatchModel  }
	]
};
  • get() - the method is mandatory - Based on called methods, it returns the built object with all requested information for the matches from specific date, grouped by competitions and filtered odds by the given providers id, markets and formated odds values.

Playoff Module

Initialize module

const playoffModule = SDK.playoff({ stageId: 'string', competition: { id: 'string', status: 'string' } });

stageId - the argument is optional and it is nested in object property ({ stageId: string }). At least stageId or competition should be passed.

competition - the argument is optional and it is nested in object property as its own object ({ id: string, status: string }). At least stageId or competition should be passed.

Usage

playoffModule
  .playoff({ stageId: 'string', competition: { id: 'string', status: 'string' } })
  .get();

Corresponding output should be:

{
 	 playoff: PlayoffFormattedModel
};

Module methods

  • playoff({ stageId: 'string', competition: { id: 'string', status: 'string' } })

    • stageId - the argument is a string. If no stageId is provided, the request will be sent with competition.
    • competition - the argument is a object with properties 'id' and 'status' ({ id: 'string', status: 'string' }). If stageId is passed, the request will be sent with stageId, NOT competition data.
  • get() - the method is mandatory - Based on called methods, it returns the built object with all requested information for the playoff.

Ranking Module

Initialize module

const rankingModule = SDK.ranking({rankingId: string, offset: string, limit: string});

Usage 1

SDK.ranking({ rankingId: 'string', offset: 'string', limit: 'string' })
	.getAvailableRankings({ scope: 'string', standingTypeSubcategory: string })
	.get();

Corresponding output should be:

{
	ranking: RankingModel,
	availableRankings: [ AvailableRankingsModel ]
};

rankingId - The argument is a string and it is required to get a single ranking by the unique id. The request will not be sent if no rankingId is provided. The request return a single ranking by the unique id.

offset and limit - the arguments are optional. The default values wiil be applied (offset: 0, limit: 100) if no offset and limit are provided. They could be used to implement pagination.

Usage 2

SDK.ranking()
	.getAvailableRankings({ scope: 'string', standingTypeSubcategory: 'string' })
	.get();

Corresponding output should be:

{
	availableRankings: [ AvailableRankingsModel ]
};

standingTypeSubcategory - The argument is optional ('ATP_SINGLES_RANKING'/ 'WTA_SINGLES_RANKING' and etc. ). The request returns a standing for a given subcategory.

scope - the argument is a string and it is optional (CURRENT or CONTINUOUS). If no scope is provided the default value will be applied (scope: CURRENT).

  • get() - the method is mandatory - Based on called methods, it returns the built object with all requested information for the ranking.

Competition Module

Usage 1

SDK.competition({ competitionId: string}).get();

Corresponding output should be:

{
	competition: CompetitionDetailsModel
};

competitionId - The argument is a string and it is required to get a single competition details by the unique id and default season: "CURRENT". The request will not be sent if no competitionId is provided.

Usage 2

SDK.competition({ competitionId: "string", season: "string" }).get();

Corresponding output should be:

{
	competition: CompetitionDetailsModel
};

seasonId - The argument is a string and it is optional to get a single competition details by given season.

  • get() - the method is mandatory - Based on called methods, it returns the built object with all requested information for the competition.

    Tournament programme module

Initialize module

const tournamentProgrammeModule = SDK.tournamentProgramme({
	competitionId: string,
	seasonId: string,
	tournamentId: string,
	filterType: string,
	sortDirection: string,
	limit: string,
	roundFilter: [ {roundId: string, tournamentId: string} ],
});

Corresponding output should be:

{
	programme: [{
		tournament: TournamentModel,
		matches: [{ round: RoundModel, games: MatchModel[] }] }],
	competition: CompetitionModel,
};

Module methods:

  • competitionId(string) - Use this method to filter by competition.

  • seasonId(string) - Use this method to filter by season.

  • tournamentId(string) - Use this method to filter by tournament.

  • roundFilter([ {roundId: string, tournamentId: string} ]) - Use this method to filter by roundIds. Cannot be applied with tournamentId property.

  • limit(string) - Use this method to limit the number of matches.

  • fiilterType(string) - Use this metod to filter upcoming matches or matches that were already played or postponed - 'fixtures'/'results'.

  • sortDirection(string) - Use this method to set the direction in which the programme matches are sorted - 'asc'/'desc'.

Module methods

  • withOdds({ bettingId: string, market: string, oddFormat: string, preEventOddsOnly: boolean })

    • bettingId - the argument is a string. If no bettingId is provided, the result will be filtered by the first provider from the response.
    • market - the argument is a string. Example: "1x2"- will return only "1x2" markets data (if there is one).
    • oddFormat - the argument is a string ( FRACTIONAL, DECIMAL, MONEYLINE ). Default value: "DECIMAL". You could pass an odds format to format odds values.
    • preEventOddsOnly - the argument is a boolean which shows odds only when the match has not started yet. The default value of the argument is false.
  • get() - the method is mandatory - Based on called methods, it returns the built object with programme information for specific competition.

Athlete programme module

Initialize module

const athleteProgrammeModule = SDK.athleteProgramme({
	playerId: string,
	seasonYear: string,
	competitionId: string,
	tournamentId: string,
	filterType: string,
	sortDirection: string,
	limit: string,
	roundFilter: [ {roundId: string, tournamentId: string} ],
});

Corresponding output should be:

{
	programme: [{
		competition: CompetitionModel,
		matches: [{ round: RoundModel, matches: MatchModel[] }] }],
	athlete: AthleteModel,
};

Module methods:

  • playerId(string) - Use this method to filter by player.

  • competitionId(string) - Use this method to filter by competition.

  • seasonId(string) - Use this method to filter by season.

  • tournamentId(string) - Use this method to filter by tournament.

  • roundFilter([ {roundId: string, tournamentId: string} ]) - Use this method to filter by roundIds. It cannot be applied if tournamentId is provided.

  • limit(string) - Use this method to limit the number of matches.

  • fiilterType(string) - Use this metod to filter upcoming games or games that were already played or postponed - 'fixtures'/'results'.

  • sortDirection(string) - Use this method to set the direction in which the programme matches are sorted - 'asc'/'desc'.

  • withOdds(options: { bettingId: string, preEventOddsOnly: boolean; oddFormat: string; }) - the argument is an object where:

    • bettingId property should be astring to filter odds result. Example: "43" - will return available odds data (if there is one) only for odds with the given provider.
    • market - the argument is a string. Example: "1x2"- will return only "1x2" markets data (if there is one).
    • preEventOddsOnly is a property which shows odds only when the match has not started yet. The default value of the argument is false.
    • oddFormat is a property which sets the type of the odds. The type argument is a string with one of the following string values: 'FRACTIONAL'/'MONEYLINE'/'DECIMAL'. The default value is set to 'DECIMAL'.
  • get() - the method is mandatory - Based on called methods, it returns the built object with athlete programme information for specific player.

Modules Errors

If some of the modules requests were not successful, the corresponding module should return an error message.

Example:

{
   matchError: "Request failed with status code 500",
   rankingError: If the ranking method is invoked with an empty object 'Ranking module initialization failed. You must provide a valid "rankingId".' error will be returned.
   ...
}

Module with no data

If the API response has no data, the module should not return anything.