Créez une expérience d’assistance personnalisée en ne présentant que les formulaires de ticket pertinents à vos clients dans votre centre d’aide. Dans ce didacticiel, vous allez apprendre à masquer des formulaires de ticket spécifiques en fonction de l’organisation d’un utilisateur.
Le workflow inclut les étapes ci-dessous.
- Étape 1 : recherchez l’identifiant du formulaire de ticket
- Étape 2 : recherchez le nom de l’organisation
- Étape 3 : modifiez le code JavaScript
Ce workflow ne fonctionne pas pour les utilisateurs non authentifiés ou n’ayant pas d’organisation. Pour ces utilisateurs, tous les formulaires s’affichent.
Si votre thème utilise Guide Templating V2, vous devez importer jQuery. Pour en savoir plus, consultez l’article : Importation ou mise à niveau de jQuery.
Étape 1 : Recherchez l’identifiant du formulaire de ticket
- Dans vos formulaires de ticket, ouvrez le formulaire de ticket approprié
- Dans l’URL, recherchez l’ID du formulaire, après la dernière barre oblique
Étape 2 : Recherchez le nom de l’organisation
- Dans Support, ouvrez l’onglet Clients
- Parcourez les organisations ou recherchez l’organisation par son nom.
Étape 3 : Modifiez le code JavaScript
Si votre thème utilise Guide Templating V2, vous devez importer jQuery. Pour en savoir plus, consultez l’article : Importation ou mise à niveau de jQuery. Ce code repose sur DOMNodeInserted Mutation Event. Les nouvelles versions de Chrome et Chromium ne prennent plus en charge cet événement de mutation. Pour être compatible avec les navigateurs qui ne prennent pas en charge DOMNodeInserted, suivez les instructions de l’observateur de mutation et effectuez la migration vers une fonction plus récente.
- Dans Guide, cliquez sur l’icône du Panneau de personnalisation () situé dans la barre latérale.
- Cliquez sur le nom du thème à modifier
- Cliquez sur le menu Options, puis sélectionnez Modifier le code, puis
Script.js
- Copiez le bloc de code ci-dessous.
$(document).ready(function() { var formID = 6502769669773; // Change this to the form ID you wish to remove var userOrgs = window.HelpCenter.user.organizations; var userOrgNames = userOrgs.map(org => org.name); if (!(userOrgNames.includes("ZENDESK"))) { // Specify the organization name here // If the user does not belong to the organization specified, remove the form option from the dropdown $('#request_issue_type_select option[value="' + formID + '"]').remove(); $('.nesty-panel').on('DOMNodeInserted', function(e) { $(this).children('ul').children().remove('#' + formID); }); } });
- Collez le code dans le modèle JavaScript du code de votre Centre d’aide.
- Remplacez la variable
formID = 6502769669773
par l’identifiant du formulaire de ticket que vous souhaitez masquer. - Remplacez
"ZENDESK"
par le nom de l’organisation pour laquelle vous voulez que le formulaire de ticket soit visible. - Si l’utilisateur ne copie pas tous les caractères, par exemple,
;
et}
du modèle, le code risque d’endommager la page - Enregistrez votre modèle et publiez les modifications.
Le code fourni réserve un espace pour d’autres organisations. Pour ajouter des formulaires et des organisations supplémentaires, copiez la déclaration if
ci-dessus et placez-la sous la déclaration if
existante ci-dessous en vous assurant d’insérer l’identifiant du formulaire de ticket et l’organisation pour vérifier l’existence de l’utilisateur. Répétez cette procédure pour le nombre de formulaires de ticket et d’organisations souhaité.
Pour modifier le comportement du code afin d’afficher un formulaire de ticket dans toutes les organisations à l’exception de celle spécifiée, supprimez l’opérateur NOT
(!)
de if
.
for (var c in HelpCenter.user.organizations) {
if (HelpCenter.user.organizations[c].name !== "ZENDESK"){
$("#TICKT_FORM_ID").remove();
}if (HelpCenter.user.organizations[c].name !== "MYORG"){
$("#TICKET_FORM_ID2").remove();
}