Login / Fichiers JSON contenant les paramètres du widget
  Retour à la documentation

Login

Fichiers JSON contenant les paramètres du widget

Les paramètres du widget sont contenus dans les fichiers JSON suivants :

Vous pouvez réutiliser les paramètres dans les fichiers et afficher le même widget sur différents paramètres. L’URL des paramètres est spécifiée dans le code d’initialisation du widget :

Copy
Full screen
Small screen
<script>
const xl = new XsollaLogin.Widget({
  // Other settings
  settingsJSON: "url_string",
  socialsJSON: "url_string",
  themeJSON: "url_string"
});
</script>

Paramètres principaux

Les principaux paramètres du widget sont les suivants :

Modèle du fichier settingsJSON :

Copy
Full screen
Small screen
{
  "authorization_methods": {
    // Authorization methods
  },
  "registration_fields": {
    // Registration fields
  },
  "email_validation": {
    // Settings for email validation
  }

  // Other widget settings
}

Méthodes d'autorisation

L’objet authorization_methods contient un tableau des méthodes d’autorisation disponibles. La page de connexion est affichée en fonction des paramètres passés.
Note
Au moins une méthode doit être passée au tableau. Chaque méthode ne peut être représentée plus d’une fois dans un tableau.

Méthodes d’autorisation disponibles :

  • email — autorisation par adresse e-mail et mot de passe. Le paramètre est passé par défaut s’il n’y a pas d’objet authorization_methods avec une liste définie de méthodes.
  • social — connexion via les réseaux sociaux. Le paramètre est passé par défaut s’il n’y a pas d’objet authorization_methods avec une liste définie de méthodes.
  • username — autorisation par nom d’utilisateur et mot de passe.
  • phone — autorisation par numéro de téléphone et par code SMS.
  • passwordless-email-code — autorisation par adresse e-mail et code envoyé par e-mail.

Exemple :

Copy
Full screen
Small screen
{
  "authorization_methods": {
    ["email", "phone"]
  }

  // Other widget settings
}

Champs d'enregistrement

L’objet registration_fields contient un tableau de champs qui sont affichés sur la page d’enregistrement du widget.
ParamètreTypeDescription
email
emailAdresse e-mail utilisateur.
username
stringCompte utilisateur.
password
passMot de passe.
password_confirm
passConfirmation du mot de passe.
given-name
stringNom d’utilisateur.
family-name
stringNom de famille de l’utilisateur.
nickname
stringPseudo de l’utilisateur.
bday
dateDate de naissance.
gender
stringGenre.
country-name
selectPays.
plateforme
multi-selectPlateforme.
promo_email_agreement
booleanConsentement à recevoir du matériel promotionnel.
Note
Le tableau doit contenir au moins un champ. Les champs sont affichés dans l’ordre dans lequel ils sont passés dans le tableau.

En outre, vous pouvez spécifier les paramètres suivants pour un champ :

  • required (boolean) — si le champ est obligatoire.
  • default_value (array) — tableau de valeurs par défaut (pour une liste de pays ou de plateformes).
  • validation (object) — paramètres de validation :
    • allowed_characters (string) — caractères autorisés pour le champ. Séparés par une virgule dans la liste comme les valeurs de l’expression régulière ;
    • max_length (number) — nombre maximal de caractères ;
    • min_length (number) — nombre minimum de caractères ;
    • regexps (array with strings) — expression régulière pour valider la valeur saisie.

Exemple :

Copy
Full screen
Small screen
{
  // Other widget settings

  "registration_fields": [
    {
      "name": "username",
      "required": false,
      "type": "str",
      "validation": {
        "allowed_characters": "A-Z, a-z, 0-9",
        "max_length": 16,
        "min_length": 5,
        "regexps": ["^.{5,16}$"]
      }
    },
    { "name": "email", "required": true, "type": "email", "validation": {} },
    { "name": "bday", "required": true, "type": "date", "validation": {} },
    {
      "name": "platform",
      "default_value": ["MacOS", "Nintendo Switch", "Steam"],
      "required": false,
      "type": "multi-select",
      "validation": {}
    },
    {
      "name": "country-name",
      "default_value": ["US", "GB", "DE"],
      "required": false,
      "type": "select",
      "validation": {}
    },
    { "name": "password", "required": true, "type": "pass", "validation": {} },
    {
      "name": "password_confirm",
      "required": false,
      "type": "pass",
      "validation": {}
    },
    {
      "name": "promo_email_agreement",
      "required": false,
      "type": "bool",
      "validation": {}
    }
  ]
}

Validation de l'adresse e-mail

L’objet email_validation contient le paramètre se_xsolla_email_validator qui valide les données saisies dans le champ email.
ParamètreTypeDescription
use_xsolla_email_validator
booleanDétermine la validation supplémentaire des données saisies dans le champ email. Si true, l’adresse e-mail est validée côté front-end et back-end avec des fonctionnalités telles que SMTP, RFC et Greylist. Si false, l’adresse e-mail est validée côté front-end uniquement. La valeur par défaut est false.
Exemple :
Copy
Full screen
Small screen
{
  // Other widget settings

  "email_validation": {
    "use_xsolla_email_validator": true
  }
}

Paramètres supplémentaires

Les paramètres supplémentaires sont passés dans l’objet JSON racine du fichier settingsJSON.
ParamètreTypeDescription
can_register
booleanDétermine l’activation de l’enregistrement utilisateur. La valeur par défaut est true.
can_reset_password
booleanDétermine l’activation de la réinitialisation du mot de passe utilisateur. La valeur par défaut est true.
stringLien vers la politique de consentement utilisateur.
stringLien vers la politique en matière de cookies.
privacy_policy
stringLien vers la politique de confidentialité.
tos_url
stringLien vers les conditions d’utilisation.
game_name
stringNom de projet ou de jeu. Affiché dans certaines méthodes d’autorisation.
Exemple :
Copy
Full screen
Small screen
{{
  // Other widget settings

  "can_register": true,
  "can_reset_password": true,
  "cookie_policy": "https://someurl.com"
}

Paramètres des réseaux sociaux

Pour la connexion via les réseaux sociaux, les paramètres suivants sont passés dans le fichier socialsJSON :

  • liste des régions ;
  • paramètres et types de réseaux sociaux pour chaque région.

Modèle du fichier socialsJSON :

Copy
Full screen
Small screen
{
  "1": {
    "primary": [
      // Array of social networks for primary type
    ],
    "secondary": [
      // Array of social networks for secondary type
    ]
  },
  "2": {
    "primary": [
      // Array of social networks for primary type
    ],
    "secondary": [
      // Array of social networks for secondary type
    ]
  },
  "3": {
    "primary": [
      // Array of social networks for primary type
    ],
    "secondary": [
      // Array of social networks for secondary type
    ]
  },
  "4": {
    "primary": [
      // Array of social networks for primary type
    ],
    "secondary": [
      // Array of social networks for secondary type
    ]
  },
  "5": {
    "primary": [
      // Array of social networks for primary type
    ],
    "secondary": [
      // Array of social networks for secondary type
    ]
  },
  "6": {
    "primary": [
      // Array of social networks for primary type
    ],
    "secondary": [
      // Array of social networks for secondary type
    ]
  }
}

Chaque région a un numéro :

  • 1 — Europe ;
  • 2 — Chine ;
  • 3 — Corée du Nord et du Sud ;
  • 4 — CEI ;
  • 5 — Amérique du Nord et du Sud ;
  • 6 — reste du monde.

Pour chaque région, le type de réseau social est défini. Il existe deux types de réseaux sociaux : les réseaux primaires (primary) et les réseaux secondaires (secondary). Les réseaux sociaux principaux sont affichés sous forme de gros boutons et sont plus visibles sur la page du widget, tandis que les réseaux sociaux secondaires sont présentés sous forme de petits boutons et sont moins visibles.

Chaque type de réseau social contient un tableau d’objets :

ParamètreTypeDescription
nom
stringNom du réseau social. Options disponibles : amazon, apple, baidu, battlenet, china_telecom, discord, email, epicgames, facebook, github, google, google-plus, instagram, kakao, linkedin, mailru, microsoft, msn, naver, ok, paradox, paypal, pinterest, qq, reddit, steam, slack, twitch, twitter, vimeo, vk, wechat, weibo, xbox, yahoo, yandex, youtube.
jwt
stringLien pour ouvrir un réseau social si l’autorisation JWT est utilisée.
oauth2
stringLien pour ouvrir un réseau social si l’autorisation basée sur le protocole OAuth 2.0 est utilisée.
Note
Chaque réseau social doit être représenté au moins une fois dans un tableau. Le tableau peut être vide.
Exemple :
Copy
Full screen
Small screen
{
  "1": {
    "primary": [{
      "name": "google",
      "jwt": "https://login.xsolla.com/api/social/google/login_redirect",
      "oauth2": "https://login.xsolla.com/api/oauth2/social/google/login_redirect"
    }],
    "secondary": [{
        "name": "facebook",
        "jwt": "https://login.xsolla.com/api/social/facebook/login_redirect",
        "oauth2": "https://login.xsolla.com/api/oauth2/social/facebook/login_redirect"
      },
      {
        "name": "twitter",
        "jwt": "https://login.xsolla.com/api/social/twitter/login_redirect",
        "oauth2": "https://login.xsolla.com/api/oauth2/social/twitter/login_redirect"
      }
    ]
  },
  "2": {
    "primary": [{
      "name": "wechat",
      "jwt": "https://login.xsolla.com/api/social/wechat/login_redirect",
      "oauth2": "https://login.xsolla.com/api/oauth2/social/wechat/login_redirect"
    }],
    "secondary": [{
        "name": "facebook",
        "jwt": "https://login.xsolla.com/api/social/facebook/login_redirect",
        "oauth2": "https://login.xsolla.com/api/oauth2/social/facebook/login_redirect"
      },
      {
        "name": "twitter",
        "jwt": "https://login.xsolla.com/api/social/twitter/login_redirect",
        "oauth2": "https://login.xsolla.com/api/oauth2/social/twitter/login_redirect"
      },
      {
        "name": "steam",
        "jwt": "https://login.xsolla.com/api/social/steam/login_redirect",
        "oauth2": "https://login.xsolla.com/api/oauth2/social/steam/login_redirect"
      }
    ]
  }

  // More regions
}

Paramètres du thème

Les paramètres du thème des widgets comprennent :

Modèle du fichier themeJSON :

Copy
Full screen
Small screen
{
  // Color and size settings

  "header": {
    // Header settings
  },
  "background": {
    // Widget background settings
  },
  "rounding": {
    // Rounding settings
  },
  "tabs": {
    // Tab settings
  },
  "primary_socials": {
    // Display settings for the primary social networks
  },
  "secondary_socials": {
    // Display settings for the secondary social networks
  },
  "scene": {
    // Scene settings
  }
}

Couleur et taille du widget

La couleur et la taille du widget sont passées dans l’objet JSON racine du fichier themeJSON.
ParamètreTypeDescription
primary_color
stringCouleur primaire du widget (couleur des boutons et des bordures des champs de saisie actifs) au format RGB ou HEX. La valeur par défaut est #0073F7.
secondary_color
stringCouleur secondaire du widget (couleur des champs de saisie inactifs) au format RGB ou HEX. La valeur par défaut est #DADADA.
error_color
stringCouleur du texte d’erreur au format RGB ou HEX. La valeur par défaut est #EB002F.
text_color
stringCouleur du texte principal au format RGB ou HEX. La valeur par défaut est #000000.

Exemple :

Copy
Full screen
Small screen
{
  // Other theme settings

  "primary_color": "#708090",
  "secondary_color": "#4682B4"
}

Arrondi

L’objet rounding contient des paramètres d’arrondi pour différents éléments du widget. La propriété s’applique simultanément aux quatre coins.

ParamètreTypeDescription
inputs
stringArrondi en pixels pour les champs actifs. La valeur par défaut est 6px.
buttons
stringArrondi en pixels pour les boutons. La valeur par défaut est 100px.
widget
stringArrondi en pixels pour le widget. La valeur par défaut est 6px.
Exemple :
Copy
Full screen
Small screen
{
  // Other theme settings

  "rounding": {
    "inputs": "8px",
    "widget": "8px"

  }
}

Arrière-plan

L’objet background contient les paramètres d’arrière-plan du widget.
ParamètreTypeDescription
color
stringCouleur d’arrière-plan au format RGB ou HEX. La valeur par défaut est #FFFFFF.
image
objectImage d’arrière-plan. L’objet contient un lien vers l’image et les paramètres d’opacité. La valeur d’opacité par défaut est 1.
Exemple :
Copy
Full screen
Small screen
{
  // Other theme settings

  "background": {
    "color": "#708090",
    "image": {
      "url": "https://someurl.com",
      "opacity": "3"
    }
  }
}

En-tête

L’objet header contient les paramètres de l’en-tête du widget : la zone située au-dessus de tous les champs du widget.
ParamètreTypeDescription
image
objectImage d’arrière-plan de l’en-tête. L’objet contient un lien vers l’image, les paramètres d’opacité et la taille de l’image d’arrière-plan. La valeur d’opacité par défaut est 1.
Les valeurs disponibles pour la taille de l’image d’arrière-plan correspondent aux valeurs de la propriété CSS background-size (la valeur par défaut est cover).
Exemple :
Copy
Full screen
Small screen
{
  // Other theme settings

  "header": {
    "image": {
      "url": "https://someurl.com",
      "opacity": "3",
      "size": "cover"
    }
  }
}

Onglets

L’objet tabs contient un paramètre hide. Ce paramètre gère l’affichage des onglets d’enregistrement ou d’autorisation sur le widget.
ParamètreTypeDescription
hide
booleanDétermine si les onglets d’autorisation ou d’enregistrement doivent être masqués dans un widget. Utilisez la valeur true pour, par exemple, masquer temporairement l’onglet d’enregistrement ou afficher séparément les pages d’enregistrement et d’autorisation. La valeur par défaut est false.
Exemple :
Copy
Full screen
Small screen
{
  // Other theme settings

  "tabs": {
    "hide": true
  }
}

Affichage des réseaux sociaux

Les objets primary_socials et secondary_socials contiennent le paramètre hide qui gère l’affichage des réseaux sociaux primaires et secondaires sur un widget.
ParamètreTypeDescription
hide
booleanDétermine si les réseaux sociaux doivent être masqués. La valeur par défaut est false.
Exemple :
Copy
Full screen
Small screen
{
  // Other theme settings

  "primary_socials": {
    "hide": true
  },
  "secondary_socials": {
    "hide": false
  }
}

Scène

L’objet scene contient les paramètres de la scène : la zone autour du widget.
ParamètreTypeDescription
color
stringCouleur d’arrière-plan au format RGB ou HEX. La valeur par défaut est #FFFFFF.
image
objectImage d’arrière-plan. L’objet contient un lien vers l’image, les paramètres d’opacité et la taille de l’image d’arrière-plan. Les valeurs disponibles pour la taille de l’image d’arrière-plan correspondent aux valeurs de la propriété CSS background-size (la valeur par défaut est cover).
Exemple :
Copy
Full screen
Small screen
{
  // Other theme settings

  "scene": {
    "color": "#708090",
    "image": {
      "url": "https://someurl.com",
      "size": "cover"
    }
  }
}
Cet article vous a été utile ?
Merci !
Que pouvons-nous améliorer ? Message
Nous sommes désolés de l'apprendre
Dites-nous pourquoi vous n'avez pas trouvé cet article utile. Message
Merci pour votre commentaire !
Nous examinerons votre message et l'utiliserons pour améliorer votre expérience.
Évaluer cette page
Évaluer cette page
Que pouvons-nous améliorer ?

Préfère ne pas répondre

Merci pour votre commentaire !
Dernière mise à jour: 22 Janvier 2024

Faute de frappe ou autre erreur dans le texte ? Sélectionnez le texte concerné et appuyez sur Ctrl+Entée.

Signaler un problème
Nous améliorons continuellement notre contenu grâce à vos commentaires.
Indiquez votre adresse e-mail pour un suivi
Merci pour votre commentaire !