Sélecteur de destinations micro front-end Overview

Le sélecteur de destination Micro-Frontend fournit une interface utilisateur dans votre application qui s’intègre facilement au référentiel Experience Manager Assets as a Cloud Service. Vous pouvez rechercher ou parcourir le dossier approprié dans le référentiel Experience Manager Assets as a Cloud Service et charger des ressources à partir de votre application.

L’interface utilisateur Micro-Frontend est mise à disposition dans votre expérience de l’application à l’aide du package Sélecteur de destination. Toutes les mises à jour du package sont automatiquement importées et le dernier sélecteur de destination déployé est automatiquement chargé dans votre application.

Vue d’ensemble

Le sélecteur de destination offre de nombreux avantages, notamment :

  • Facile à intégrer avec n’importe quelle application Adobe ou autre qu’Adobe utilisant la bibliothèque JavaScript Vanilla.
  • Facile à gérer, car les mises à jour du package Sélecteur de destination sont automatiquement déployées vers le sélecteur de destination disponible pour votre application. Aucune mise à jour n’est requise dans votre application pour télécharger les dernières modifications.
  • Facile à personnaliser, car il existe des propriétés qui contrôlent l’affichage du sélecteur de destination dans votre application.
  • Recherche de texte intégral pour accéder rapidement aux dossiers où charger des ressources à partir de votre application.
  • Possibilité de créer des dossiers, de les trier par ordre croissant ou décroissant, puis de les afficher en mode Liste, Grille, Galerie ou Cascade.

Le but de cet article est de montrer comment utiliser le sélecteur de destination avec une application Adobe sous Unified Shell ou lorsque vous avez déjà généré un imsToken pour l’authentification. Dans cet article, ces workflows sont appelés flux non-SUSI.

Effectuez les tâches suivantes pour intégrer et utiliser le sélecteur de destination avec votre référentiel Experience Manager Assets as a Cloud Service :

Intégration du sélecteur de destination à l’aide de Vanilla JS integration-with-vanilla-js

Vous pouvez intégrer n’importe quelle application Adobe ou autre qu’Adobe avec un référentiel Experience Manager Assets as a Cloud Service et sélectionner des ressources dans l’application.

L’intégration est effectuée en important le package Sélecteur de destination et en se connectant à Assets as a Cloud Service à l’aide de la bibliothèque JavaScript Vanilla. Vous devez modifier un index.html ou tout fichier approprié dans votre application vers -

  • Définition des détails d’authentification
  • Accès au référentiel Assets as a Cloud Service
  • Configuration des propriétés d’affichage du sélecteur de destination

Vous pouvez effectuer une authentification sans définir certaines des propriétés IMS, si :

  • Vous intégrez une application Adobe sur Unified Shell.
  • Un jeton IMS est déjà généré pour l’authentification.

Prérequis prerequisites

Définissez les conditions préalables dans le fichier index.html ou un fichier similaire dans l’implémentation de votre application pour définir les détails d’authentification permettant d’accéder au référentiel Experience Manager Assets as a Cloud Service. Les prérequis sont les suivants :

  • imsOrg
  • imsToken
  • apikey

Installation installation

Les sélecteurs de destination sont disponibles via le réseau CDN ESM (par exemple, esm.sh/skypack) et la version UMD.

Dans les navigateurs utilisant la version UMD (recommandé) :

Dans les navigateurs utilisant la version UMD (recommandé) :

<script src="https://experience.adobe.com/solutions/CQ-assets-selectors/static-assets/resources/assets-selectors.js"></script>

<script>
  const { renderAssetSelector } = PureJSSelectors;
</script>

Dans les navigateurs avec la prise en charge import maps à l’aide de la version du réseau CDN ESM  :

<script type="module">
  import { AssetSelector } from 'https://experience.adobe.com/solutions/CQ-assets-selectors/static-assets/resources/@assets/selectors/index.js'
</script>

Dans la fédération de modules Deno/Webpack à l’aide de la version du réseau CDN ESM  :

import { AssetSelector } from 'https://experience.adobe.com/solutions/CQ-assets-selectors/static-assets/resources/@assets/selectors/index.js'

Destination sélectionnée selected-destination

Le sélecteur de destination reçoit un rappel de onItemSelect, onTreeToggleItem ou onTreeSelectionChange avec le répertoire sélectionné contenant l’objet (répertoire, image, etc.).

Syntaxe du schéma

interface SelectedDestination {
  id: string;
  children: SelectedDestination[];
  'repo:repositoryId': string;
  'dc:format': string;
  'repo:assetClass': string;
  'storage:directoryType': string;
  'storage:region': string;
  'repo:name': string;
  'repo:path': string;
  'repo:ancestors': string[];
  'repo:createDate': string;
  'storage:assignee':

  { type: string; id: string; }
  ;
  'repo:assetId': string;
  'aem:published': boolean;
  'repo:createdBy': string;
  'repo:state': string;
  'repo:id': string;
  'repo:modifyDate': string;
  _page:

  { orderBy: string; count: number; };
}

Le tableau suivant décrit certaines des propriétés importantes de la destination sélectionnée.

Propriété
Type
Explication
repo:repositoryId
chaîne
Identifiant unique du référentiel dans lequel la ressource est stockée.
repo:id
chaîne
Identifiant unique de la ressource.
repo:assetClass
chaîne
Classification de la ressource (par exemple, image ou vidéo, document).
repo:name
chaîne
Nom de la ressource, y compris l’extension de fichier.
repo:size
nombre
Taille de la ressource en octets.
repo:path
chaîne
Emplacement de la ressource dans le référentiel.
repo:ancestors
Array<string>
Tableau d’éléments ancêtres de la ressource dans le référentiel.
repo:state
chaîne
État actuel de la ressource dans le référentiel (par exemple, active, supprimée, etc.).
repo:createdBy
chaîne
L’utilisateur, l’utilisatrice ou le système qui a créé la ressource.
repo:createDate
chaîne
Date et heure de création de la ressource.
repo:modifiedBy
chaîne
L’utilisateur, l’utilisatrice ou le système qui a modifié la ressource pour la dernière fois.
repo:modifyDate
chaîne
Date et heure de la dernière modification de la ressource.
dc:format
chaîne
Le format de la ressource.
_page
orderBy: string; count: number;
Inclut le numéro de page du document.

Pour obtenir la liste complète des propriétés ainsi qu’un exemple détaillé, consultez la page Exemple de code de sélecteur de destination.

Exemple pour le flux non-SUSI non-ims-vanilla

Cet exemple montre comment utiliser le sélecteur de destination avec un flux non-SUSI lors de l’exécution d’une application Adobe sous Unified Shell ou lorsque vous avez déjà généré des imsToken pour l’authentification.

Insérez le package Sélecteur de destination dans votre code à l’aide de la balise script, comme illustré dans les lignes 6 à 15 de l’exemple ci-dessous. Une fois le script chargé, vous pouvez utiliser la variable globale PureJSSelectors. Définissez les propriétés du sélecteur de destination comme illustré aux lignes 16 à 23. Les propriétés imsOrg et imsToken sont toutes deux requises pour l’authentification dans un flux non-SUSI. La propriété handleSelection sert à gérer les ressources sélectionnées. Pour effectuer le rendu du sélecteur de destinations, appelez la fonction renderDestinationSelector comme indiqué dans la ligne 17. Le sélecteur de destination s’affiche dans l’élément de conteneur <div>, comme indiqué dans les lignes 21 et 22.

En suivant ces étapes, vous pouvez utiliser le sélecteur de destination avec un flux non-SUSI dans votre application Adobe.

<!DOCTYPE html>
<html>
<head>
    <title>Destination Selector</title>
    <script src="https://experience.adobe.com/solutions/CQ-assets-selectors/assets/resources/assets-selectors.js"></script>
    <script>
        // get the container element in which we want to render the DestinationSelector component
        const container = document.getElementById('destination-selector-container');
        // imsOrg and imsToken are required for authentication in non-SUSI flow
        const destinationSelectorProps = {
            imsOrg: 'example-ims@AdobeOrg',
            imsToken: "example-imsToken",
            apiKey: "example-apiKey-associated-with-imsOrg",
            handleSelection: (assets: SelectedAssetType[]) => {},
        };
        // Call the `renderDestinationSelector` available in PureJSSelectors globals to render DestinationSelector
        PureJSSelectors.renderDestinationSelector(container, destinationselectorprops);
    </script>
</head>

<body>
    <div id="destination-selector-container" style="height: calc(100vh - 80px); width: calc(100vw - 60px); margin: -20px;">
    </div>
</body>

</html>

Pour obtenir un exemple détaillé, consultez Exemple de code de sélecteur de destination.

Utilisation des propriétés du sélecteur de destination destination-selector-properties

Vous pouvez utiliser les propriétés du sélecteur de destination pour personnaliser son rendu. Le tableau suivant répertorie les propriétés que vous pouvez utiliser pour personnaliser et utiliser le sélecteur de destination :

Propriété
Type
Requis
Valeur par défaut
Description
imsOrg
chaîne
Oui
Identifiant Adobe Identity Management System (IMS) attribué lors de l’approvisionnement de Adobe Experience Manager en tant que Cloud Service pour votre organisation. La clé imsOrg est requise pour vous authentifier, que l’organisation à laquelle vous accédez se trouve sous Adobe IMS ou non.
imsToken
chaîne
Non
Jeton de support IMS utilisé pour l’authentification. imsToken n’est pas est obligatoire si vous utilisez le flux SUSI. Il est toutefois obligatoire si vous utilisez le flux non-SUSI.
apiKey
chaîne
Non
Clé d’API utilisée pour accéder au service AEM Discovery. apiKey n’est pas obligatoire si vous utilisez le flux SUSI. Il est toutefois obligatoire dans un flux non-SUSI.
rootPath
chaîne
Non
/content/dam/
Chemin du dossier à partir duquel le sélecteur de destination affiche vos ressources. rootPath peut également être utilisé sous la forme d’encapsulation. Par exemple, avec le chemin suivant, /content/dam/marketing/subfolder/, le sélecteur de destination ne vous permet pas de parcourir les dossiers parents, mais affiche uniquement les dossiers enfants.
hasMore
booléen
Non
Lorsque l’application dispose de davantage de contenu à afficher, vous pouvez utiliser cette propriété pour ajouter un chargeur chargeant le contenu afin de le rendre visible dans l’application. Il s’agit d’un indicateur montrant que le chargement du contenu est en cours.
orgName
booléen
Non
Il s’agit du nom de l’organisation (probablement orgID) associé à AEM
initRepoID
chaîne
Non
Il s’agit du chemin d’accès du référentiel de ressources que vous souhaitez utiliser dans une vue initiale par défaut
onCreateFolder
chaîne
Non
La propriété onCreateFolder vous permet d’ajouter une icône qui ajoute un nouveau dossier dans l’application.
onConfirm
chaîne
Non
Il s’agit d’un rappel lorsque vous appuyez sur le bouton de confirmation.
confirmDisabled
chaîne
Non
Cette propriété contrôle le bouton de confirmation.
viewType
chaîne
Non
La propriété viewType sert à spécifier les vues que vous utilisez pour afficher les ressources.
viewTypeOptions
chaîne
Non
Cette propriété est liée à la propriété viewType. vous pouvez spécifier une ou plusieurs vues pour afficher les ressources. Les viewTypeOptions disponibles sont les suivantes : affichage Liste, affichage Grille, affichage Galerie, affichage Cascade et affichage Arborescence.
itemNameFormatter
chaîne
Non
Cette propriété vous permet de mettre en forme le nom de l’élément.
i18nSymbols
Object<{ id?: string, defaultMessage?: string, description?: string}>
Non
Si les traductions prêtes à l’emploi ne sont pas suffisantes pour répondre aux besoins de votre application, vous pouvez exposer une interface par laquelle vous pouvez transmettre vos propres valeurs localisées et personnalisées via la propriété i18nSymbols. Le transfert d’une valeur par le biais de cette interface remplace les traductions fournies par défaut par les vôtres. Pour effectuer le remplacement, vous devez transmettre un objet Descripteur de message valide à la clé de i18nSymbols que vous voulez remplacer.
inlineAlertSetup
chaîne
Non
Il ajoute un message d’alerte que vous souhaitez transmettre à l’application. Par exemple, ajouter un message d’alerte indiquant « Vous n’êtes pas autorisé à accéder à ce dossier ».
intl
Objet
Non
Le sélecteur de destination fournit des traductions prêtes à l’emploi par défaut. Vous pouvez sélectionner la langue de traduction en fournissant une chaîne de paramètres régionaux valide via la propriété intl.locale. Par exemple : intl={{ locale: "es-es" }}

. Les chaînes de paramètres régionaux prises en charge suivent la norme ISO 639 - Codes pour la représentation des noms des normes linguistiques.

Liste des paramètres régionaux pris en charge : anglais (en-us, par défaut), espagnol (es-es), allemand (de-de), français (fr-FR), italien (it-it), japonais (ja-jp), coréen (ko-kr), portugais (pt-br), chinois (traditionnel, zh-cn), chinois (Taïwan, zh-tw).

Exemples d’utilisation des propriétés du sélecteur de destination usage-examples

Vous pouvez définir les propriétés du sélecteur de destination dans le fichier index.html pour personnaliser son affichage dans votre application.

Exemple 1 : créer un dossier dans le sélecteur de destination

Le sélecteur de destination vous permet de créer un dossier dans lequel charger, déplacer ou copier des ressources à cet emplacement.

create-folder-destination-selector

Exemple 2 : définir le type de vue du sélecteur de destination

Le sélecteur de destination affiche un large éventail de ressources dans les quatre vues Liste, Grille, Galerie et Cascade. Pour spécifier le type de vue par défaut, vous pouvez utiliser la propriété viewType. La propriété viewTypeOptions est utilisée avec la propriété viewType pour indiquer d’autres types de vues afin que d’autres options de type de vue puissent être affichées dans une liste déroulante. Un seul argument peut être utilisé si vous ne souhaitez afficher qu’une seule option.

viewtype-destination-selector

Exemple 3 : initialiser le chemin d’accès au dossier de ressources

Utilisez la propriété path pour définir le nom du dossier qui s’affiche automatiquement lors du rendu du sélecteur de destination.

initialize-folder-path

Utiliser le sélecteur de destination using-destination-selector

Une fois que le sélecteur de destination est configuré et que vous êtes authentifié(e) pour l’utiliser avec votre application Adobe Experience Manager as a Cloud Service, vous pouvez sélectionner des ressources ou effectuer d’autres opérations pour rechercher vos ressources dans le référentiel.

using-destination-selector

Barre de recherche search-bar

Le sélecteur de destination vous permet d’effectuer une recherche de texte intégral des ressources dans le référentiel sélectionné. Par exemple, si vous saisissez le mot-clé wave dans la barre de recherche, toutes les ressources qui contiennent le mot-clé wave dans l’une des propriétés de métadonnées s’affichent.

Tri sorting

Vous pouvez trier les ressources dans le sélecteur de destination selon le nom, la dimension ou la taille. Vous pouvez également trier les ressources par ordre croissant ou décroissant.

Référentiel de ressources assets-repo

Le sélecteur de destination vous permet également d’afficher les données du référentiel de votre choix disponibles dans l’application AEM. Vous pouvez utiliser la propriété repositoryID pour initialiser le chemin du dossier de destination que vous souhaitez afficher à la première instance du sélecteur de destination.

Ajouter un suffixe ou un préfixe add-suffix-or-prefix

Il s’agit d’un exemple de la propriété optionsFormSetup. Vous pouvez l’utiliser pour confirmer la sélection. Elle est transmise sur l’événement onConfirm.

Créer un dossier create-new-folder

Il vous permet de créer un dossier dans le dossier de destination de votre Adobe Experience Manager en tant que Cloud Service.

Types de vues types-of-view

Le sélecteur de destination vous permet d’afficher la ressource dans quatre vues différentes :

  • vue liste  : la vue Liste affiche les fichiers et dossiers défilables dans une seule colonne.
  • vue grille  : la vue Grille affiche les fichiers et dossiers défilables dans une grille de lignes et de colonnes.
  • vue galerie  : la vue Galerie affiche les fichiers ou les dossiers dans une liste horizontale centrée et verrouillée.
  • vue cascade  : la vue Cascade affiche les fichiers ou les dossiers sous la forme d’un pont.

Infos info

L’icône d’informations ou d’informations vous permet d’afficher les métadonnées de la ressource sélectionnée. Il comprend divers détails tels que les dimensions, la taille, la description, le chemin, la date de modification et la date de création. Les informations de métadonnées sont fournies lors du chargement ou de la copie ou de la création d’une ressource.

Sélectionner un dossier select-folder

Le bouton Sélectionner un dossier permet de sélectionner des ressources pour effectuer diverses opérations associées à properties sur le sélecteur de destination.

recommendation-more-help
fbcff2a9-b6fe-4574-b04a-21e75df764ab