Erstellen Sie eine Nutzeroberfläche
Erstellen, testen und bearbeiten Sie eine eigene Nutzeroberfläche, die die Funktionen des Stripe-Dashboards erweitert.
Konfigurieren Sie für Ihre App mithilfe von TypeScript, React sowie des UI Extensions SDK und des UI-Toolkits von Stripe eine Nutzeroberfläche, die über das Stripe-Dashboard hinausgeht. In diesem Leitfaden erfahren Sie, wie Sie durch das Erstellen und Löschen von Ansichten eine einfache Nutzeroberfläche erstellen können.
Technische Informationen zu diesem Thema finden Sie in dem Artikel Funktionsweise von Erweiterungen der Nutzeroberfläche.
Eine Ansicht hinzufügen
Verwenden Sie Ansichten, um die Nutzeroberfläche Ihrer App zu entwickeln. Eine Ansicht ist eine Kombination aus einer React-Komponente und einem bestimmten Darstellungsfeld. Die React-Komponente besteht aus UI-Komponenten aus unserem UI-Toolkit. Das Darstellungsfeld ist die Seite bzw. der Abschnitt des Stripe-Dashboards, wo Sie es anzeigen möchten.
Verwenden Sie den Befehl
add
aus dem Stammverzeichnis Ihres Projekts:Command Linestripe apps add view
Folgen Sie der Eingabeaufforderung:
- Wählen Sie das Darstellungsfeld aus, in dem Ihre Ansicht angezeigt wird. Dies ist eine Liste der verfügbaren Darstellungsfelder.
- Benennen Sie Ihre Ansicht (z. B. MeinKomponentenname). Die CLI schlägt Namen anhand Ihrer Darstellungsfeldauswahl vor.
Stripe fügt Ihre Ansicht automatisch dem Array
views
im Manifest Ihrer App hinzu, erzeugt eine neue React-Komponenten-Datei im Verzeichnissrc/views
und erstellt daneben eine Testdatei für die Komponenten.
App in der Vorschau anzeigen
Sie können Ihre App lokal ausführen, Aktualisierungen vornehmen und Ihre Änderungen im Dashboard in der Vorschau anzeigen.
Starten Sie den Entwicklungsserver im Stammverzeichnis Ihres Projekts:
Command Linestripe apps start
Drücken Sie Enter, um den Browser zu öffnen.
Klicken Sie auf Weiter, um eine Vorschau der App in Ihrem Stripe-Konto anzuzeigen:
Um den Entwicklungsserver zu deaktivieren, geben Sie in der Betreffzeile Ctrl+C ein.
Wenn der Entwicklungsserver aktiv ist, können Sie Änderungen an Ihrer App vornehmen und automatisch im Dashboard anzeigen, ohne die Seite aktualisieren zu müssen. Bis Fehler behoben sind, werden diese automatisch im Stripe-Dashboard, den Entwicklungstools Ihres Browsers und der Stripe-CLI angezeigt.
Vorschauen wechseln
Sie können die Vorschau der lokalen Version Ihrer App deaktivieren, um eine Vorschau einer kürzlich installierten Version Ihrer App im Test-Modus anzuzeigen. Wenn Sie noch nie eine Version Ihrer App im Test-Modus installiert haben, ist ein Wechsel der Vorschau nicht möglich.
Um eine Vorschau der zuletzt installierten Version Ihrer App im Test-Modus anzuzeigen, führen Sie Ihren Entwicklungsserver aus und befolgen Sie diese Schritte:
- Klicken Sie oben rechts in Ihrer App auf das Überlaufmenü .
- Klicken Sie auf App-Vorschau deaktivieren und dann auf Weiter.
Auf Stripe-Objekte im Dashboard zugreifen
Wenn Sie einem Darstellungsfeld eine Komponente zuweisen, kann diese mithilfe des Objekts environment.
Kontext über das Stripe-Objekt auf dieser Seite erhalten.
Wenn Sie beispielsweise eine Ansicht erstellen, die das Darstellungsfeld stripe.
verwendet, gibt das Objekt environment.
einen customer
-Objekttyp und die ID des aktuellen Kunden/der aktuellen Kundin zurück. Sie können diese Werte dann verwenden, um weitere Informationen über das Customer-Objekt zu erhalten und Attribute wie Adresse, Beschreibung usw. zu ändern.
Einen Index der Objekte, die ein Darstellungsfeld bereitstellt, finden Sie in der Dokumentation zu Darstellungsfeldern.
Beispiel: Kundenname aktualisieren
Mit dem folgenden Code werden die Kundennamen mithilfe des Stripe Node.js-API-Clients und der environment.
-ID im Darstellungsfeld aktualisiert:
Fügen Sie die Berechtigung
customer_
zu Ihrer App hinzu:write Command Linestripe apps grant permission "customer_write" "Allows the app to update the name of the customer."
Verwenden Sie die Stripe-API in Ihrer App, um den Namen des/der Kund/in zu aktualisieren:
import {createHttpClient, STRIPE_API_KEY} from '@stripe/ui-extension-sdk/http_client'; import Stripe from 'stripe'; // Initiate communication with the stripe client. const stripe = new Stripe(STRIPE_API_KEY, { httpClient: createHttpClient(), apiVersion: '2022-08-01', }) const App = ({environment, userContext}) => { // Call the Stripe API to make updates to customer details. const updateCurrentCustomer = async (newCustomerName) => { try { // If the user has permission to update customers, this should succeed. const updatedCustomer = await stripe.customers.update( // We can use the current objectContext to get the customer ID. environment.objectContext.id, {name: newCustomerName} ); console.log(updatedCustomer.name); } catch (error) {} }; }
Beispiel: Daten im Dashboard aktualisieren
Wenn Ihre App Daten im Dashboard ändert, verwenden Sie die Funktion useRefreshDashboardData, um einen Rückruf zu generieren und die Daten zu aktualisieren:
import {useCallback} from 'react'; import {useRefreshDashboardData} from '@stripe/ui-extension-sdk/context'; const App = () => { // Get the callback used to refresh the dashboard data const refreshDashboardData = useRefreshDashboardData(); // Stripe API call const updateCustomer = useCallback(async () => { try { await updateCurrentCustomer(); // Call to refresh the data in the Dashboard refreshDashboardData(); } catch (error) {} }, [refreshDashboardData]); }
Drittanbieter-APIs nutzen
Ihre Nutzeroberflächen-Erweiterung kann APIs von Drittanbietern (Ihre eigene API oder eine beliebige öffentliche API) aufrufen, so fordert Ihre App Daten an bzw. sendet diese.
Fügen Sie mit dem Befehl
grant url
die URL der Drittanbieter-API hinzu:Command Linestripe apps grant url "https://*.api.example.com/path/" "Send data to example service..."
Die Connect-src-URL muss die folgenden Anforderungen erfüllen:
- Verwenden Sie das sichere HTTPS-Protokoll (Beispiel:
https://www.
).example. com/api/users/ - Geben Sie einen Pfad an (Beispiel: Die URL
https://www.
ist gültig, nicht die URLexample. com/api/users/ https://www.
). Durch das Hinzufügen eines Basispfads mit einem nachstehenden Schrägstrich werden alle nachfolgenden Pfade abgedeckt (Beispiel:example. com/ https://www.
ermöglicht Aufrufe vonexample. com/api/ https://www.
).example. com/api/users/abc123/address - Es darf sich dabei nicht um einen Aufruf einer Stripe-API handeln.
- Wenn Sie einen Platzhalter (
*
) verwenden, muss dieser im DNS-Label ganz links stehen (Beispiel:https://*.
).example. com/api/users/
Mit Stripe Apps wird die URL im Array
connect-src
des App-Manifests Ihres Projekts hinzugefügt:"ui_extension": { "views": [], "actions": [], "content_security_policy": { "connect-src": [ "https://*.api.example.com/", "https://o0.ingest.example.io/api/", ], "purpose": "Send data to example service. The Example app sends data to the Example service to provide its functionality and sends anonymous error reports to our partner Example for debugging purposes" } }
Um eine connect-src-URL zu entfernen, können Sie auch die Stripe-CLI verwenden:
Command Linestripe apps revoke connect-src "https://*.api.example.com/path/"
- Verwenden Sie das sichere HTTPS-Protokoll (Beispiel:
Um eine Vorschau Ihrer App im Browser anzuzeigen, starten Sie Ihren Entwicklungsserver und folgen Sie den Eingabeaufforderungen der CLI:
Command Linestripe apps start
Fügen Sie den
fetch
-Aufruf mit der URL Ihrer Drittanbieter-API in Ihre App ein.Wenn Sie zum Beispiel die connect-src-URL
https://www.
zu Ihrem App-Manifest hinzufügen, können Sie folgenden Fetch-Aufruf verwenden:example. com/api/users const makeRequestToService = (endpoint, requestData) => { return fetch(`https://www.example.com/api/${endpoint}/`, { 'POST', headers: { 'Content-Type': 'application/json', }, body: requestData, }); };
Laden Sie eine erweiterte Manifest-Datei um verschiedene App-Manifestwerte in der lokalen Entwicklung und Produktion zu verwenden.
Wenn die Drittanbieter-API über eine JavaScript-Client-Bibliothek verfügt, können Sie die Abhängigkeit mit dem Befehl
npm add
zu Ihrer App hinzufügen.
Fehlerbehebung der App
Während Sie Ihre App entwickeln, können Sie die Entwickler-Tools-Konsole Ihres Browsers als Fehlerbehebungs-Tool verwenden.
So isolieren Sie die Nachrichten bezüglich Ihrer App:
- Finden Sie Ihre App-ID im App-Manifest.
- Geben Sie im Bereich Konsole Ihres Entwickler-Tools-Browsers
[Stripe App <your app ID>]
in das Feld Filter ein. Es sollte in etwa folgendermaßen aussehen:[Stripe App com.
.example. helloworld]
Tests für Ihre Ansicht schreiben
Wir empfehlen, Tests für Ihre Ansichten zu erstellen. Mit Komponententests können Sie nicht nur überprüfen, ob sich Ihre Ansicht erwartungsgemäß verhält, sondern sie sorgen auch für mehr Sicherheit bei der zukünftigen Durchführung von Änderungen am Code.
Wenn Sie Ihre Ansicht erstellen, enthält die auf .
endende Testdatei ein Muster der Standardansicht:
import {render, getMockContextProps} from "@stripe/ui-extension-sdk/testing"; import {ContextView} from "@stripe/ui-extension-sdk/ui"; import App from "./App"; describe("App", () => { it("renders ContextView", () => { const {wrapper} = render(<App {...getMockContextProps()} />); expect(wrapper.find(ContextView)).toContainText("save to reload this view"); }); });
Sie können alle Tests mit dem enthaltenen Jest-Test-Runner mit dem Befehl npm run test
oder yarn test
ausführen. Wenn Sie beliebte React-Testwerkzeuge wie Testing Library und Enzyme verwendet haben, ist Ihnen das in @stripe/ui-extension-sdk/testing
enthaltene Testpaket bereits vertraut.
Ein typischer Test verläuft nach diesem Muster:
- Geben Sie Ihre Ansicht wieder.
- Stellen Sie eine Behauptung über den Ausgangszustand auf, z. B. dass ein Text vorhanden ist.
- Interagieren Sie mit der Ansicht.
- Stellen Sie eine Behauptung über den neuen Zustand auf, z. B. dass ein neuer Text angezeigt wird.
Weitere Methoden und Funktionen des Testpakets finden Sie in unserem Hilfeartikel zu Nutzeroberflächentests.