Social actions
Overview
We suggest using social actions for audience multiplication — share, post and invite friends to the game. Platforms such as VK and OK allow you to use the tools built into the platform. The rest of the platforms will imitate the functionality through the usual link sharing with the ability to add a comment and sometimes pictures.
The list of supported social networks and messengers for sharing:
- Telegram
- Vkontakte
- Odnoklassniki
- Viber
For better parsing of games by messengers and social networks, we recommend placing Open Graph meta tags in the game. And also fill in the title and description. This is useful in terms of SEO optimization. An example of placing meta tags is shown below:
// Fill in the basic information about the game
<title>My awesome game 2</title>
<meta name="og:title" content="My awesome game 2">
<meta name="description" content="There are not enough words to describe the awesomeness of the game">
<meta name="og:description" content="There are not enough words to describe the awesomeness of the game">
<meta name="og:image" content="/img/ogimage.png">
Supported platforms
Platforms without support
To check that sharing is allowed and supported on the platform:
- JavaScript
- Unity
// Is sharing supported
ss.socials.isSupportsShare;
// Is sharing supported
SS_Socials.IsSupportsShare();
Share
FREEBy default, when calling the share
method, you can share a link to the game. We will determine the link ourselves based on the platform and insert the necessary text. The text is taken from the project name in the control panel or from the og:title
meta tag or simply from the title
tag.
Platforms with native functionality
Platforms without support
- JavaScript
- Unity
// Is native sharing supported
ss.socials.isSupportsNativeShare;
// Is native sharing supported
SS_Socials.IsSupportsNativeShare();
In platforms without native support for this method, there will be used an overlay with an offer to share on social networks and messengers.
- JavaScript
- Unity
ss.socials.share();
SS_Socials.Share();
Share with free text adding:
- JavaScript
- Unity
ss.socials.share({
text: `I tapped the square 73 times in 5 seconds!
Now I am number 23 in "Fastest Fingers" list.
Can you beat out me?`
});
SS_Socials.Share(text = 'I tapped the square 73 times in 5 seconds!
Now I am number 23 in "Fastest Fingers" list.
Can you beat out me?');
Share with an arbitrary link adding:
- JavaScript
- Unity
ss.socials.share({
url: `${ss.app.url}?invitedBy=${ss.player.id}`
});
SS_Socials.Share(url = SS_App.Url());
Share with an optional picture adding:
- JavaScript
- Unity
ss.socials.share({
image: 'https://spellsync.com/ogimage.png'
});
SS_Socials.Share(image = "https://spellsync.com/ogimage.png");
Support for images through native methods of social networks is implemented only in Vkontakte through the attachment format photo123456_123456
and Odnoklassniki through the attachment format 123456
, or URL of images uploaded through SpellSync to the platform (ss.images.upload()
) for the rest, the image parameter will be ignored, only url and text are available.
Fully customizable sharing:
- JavaScript
- Unity
ss.socials.share({
text: 'Join me in the game "My awesome game 2"',
url: ss.app.url,
image: 'https://spellsync.com/ogimage.png'
});
SS_Socials.Share(
text = 'Join me in the game "My awesome game 2"',
url = SS_App.Url(),
image = 'https://spellsync.com/ogimage.png'
);
You can subscribe to on share event:
- JavaScript
- Unity
ss.socials.on('share', (success) => {
// success = true if successful share
});
//Subscribe to event
private void OnEnable()
{
SS_Socials.OnShare += OnShare;
}
//Unsubscribe from event
private void OnDisable()
{
SS_Socials.OnShare -= OnShare;
}
// success = true if successful share
private void OnShare(bool success) => ConsoleUI.Instance.Log("SOCIALS: SHARE: " + success);
Post
FREEAs opposed to share method, the post method involves posting to the player’s friends news feed.
Platforms with native functionality
Platforms without support
- JavaScript
- Unity
// Is native posting supported
ss.socials.isSupportsNativePosts;
// Is native posting supported
SS_Socials.IsSupportsNativePosts();
On the platforms without native supporting for this method, there will be used an overlay with an offer to share, as in the case of the share
method.
The usage logic duplicates the share
method.
- JavaScript
- Unity
ss.socials.post();
SS_Socials.Post();
Fully customizable post:
- JavaScript
- Unity
ss.socials.post({
text: 'Join me in the game "My awesome game 2"',
url: ss.app.url,
image: 'https://spellsync.com/ogimage.png'
});
SS_Socials.Share(
text = 'Join me in the game "My awesome game 2"',
url = SS_App.Url(),
image = 'https://spellsync.com/ogimage.png'
);
You can subscribe to on post event:
- JavaScript
- Unity
ss.socials.on('post', (success) => {
// success = true if successful post
});
//Subscribe to event
private void OnEnable()
{
SS_Socials.OnPost += OnPost;
}
//Unsubscribe from event
private void OnDisable()
{
SS_Socials.OnPost -= OnPost;
}
// success = true, if the "post" action is successful
private void OnPost(bool success) => ConsoleUI.Instance.Log("SOCIALS: ON POST: " + success);
Invite friends
FREEShows the player a friends list to whom you can send the invitation.
Platforms with native functionality
Platforms without support
- JavaScript
- Unity
// Are native invites supported
ss.socials.isSupportsNativeInvite;
// Are native invites supported
SS_Socials.IsSupportsNativeInvite();
On the platform without native supporting of this method, there will be used an overlay with the offer to invite friends, as in the case of share
and post
methods.
The usage logic duplicates the share
method.
- JavaScript
- Unity
ss.socials.invite();
SS_Socials.Invite();
Customizable text for some platforms:
- JavaScript
- Unity
ss.socials.invite({
text: 'Join me in the game "My awesome game 2"'
});
SS_Socials.Invite(
text = 'Join me in the game "My awesome game 2"',
url = SS_App.Url(),
image = 'https://spellsync.com/ogimage.png'
);
You can subscribe to on invite event:
- JavaScript
- Unity
ss.socials.on('invite', (success) => {
// success = true if successful invite
});
//Subscribe to event
private void OnEnable()
{
SS_Socials.OnInvite += OnInvite;
}
//Unsubscribe from event
private void OnDisable()
{
SS_Socials.OnInvite -= OnInvite;
}
// success = true if successful invite
private void OnInvite(bool success) => ConsoleUI.Instance.Log("SOCIALS: ON INVITE: " + success);
The method accepts the same object as in the case of share
and post
, but today only text
is used.
Join community
FREEShows the player an overlay with the opportunity to join the community (if the platform allows) or opens a link to the community in a new tab.
Supported platforms
Platforms without support
- JavaScript
- Unity
// check is community join is available on platform
ss.socials.canJoinCommunity;
// check is community join is available on platform
SS_Socials.CanJoinCommunity();
Platforms with native functionality
Platforms without support
- JavaScript
- Unity
// check is native community join is supported
ss.socials.isSupportsNativeCommunityJoin;
// check is native community join is supported
SS_Socials.IsSupportsNativeCommunityJoin();
Join community:
- JavaScript
- Unity
ss.socials.joinCommunity();
SS_Socials.JoinCommunity();
You can subscribe to on join community event:
- JavaScript
- Unity
ss.socials.on('joinCommunity', (success) => {
// success = true if successful join community
});
//Subscribe to event
private void OnEnable()
{
SS_Socials.OnJoinCommunity += OnJoinCommunity;
}
//Unsubscribe from event
private void OnDisable()
{
SS_Socials.OnJoinCommunity -= OnJoinCommunity;
}
// success = true if successful join community
private void OnJoinCommunity(bool success) => ConsoleUI.Instance.Log("SOCIALS: ON JOIN COMMUNITY: " + success);
Working with parameters for sharing
You may need to create a link to invite a player that contains the inviter's ID and a gift for the invited player. To do this, you need to add these parameters to the game link on the platform. All platforms require different ways of forming URLs. We have combined the creation of links into one method. When you follow this link, all previously passed parameters are available to you.
Create a sharing link
FREE- JavaScript
- Unity
const shareUrl = ss.socials.makeShareUrl({
// any of your parameters
fromId: ss.player.id,
gift: 'GOLD_SWORD_X5'
});
// https://vk.com/app7869399#eyJmcm9tSWQiOjE4MDcwMTksImdpZnQiOiJHT0xEX1NXT1JEX1g1In0=
public string MakeShareLink(string content)
{
return SS_Socials.MakeShareLink(content);
}
Read parameters when following the link
FREE- JavaScript
- Unity
// any of your parameters specified in the link
const fromId = ss.socials.getShareParam('fromId'); // 123456
const gift = ss.socials.getShareParam('gift'); // "GOLD_SWORD_X5"
// ID of the player who shared the link
int sharePlayerID = SS_Socials.GetSharePlayerID();
// Content in the link
string shareContent = SS_Socials.GetShareContent();
Stay in Touch
Other documents of this chapter available Here. To get started, welcome to the Tutorials chapter.
SpellSync Community Telegram
: @spellsync.
For your suggestions e-mail
: [email protected]
We Wish you Success!