pos. cart. line-item-details. action. renderTarget
Target
A full-screen extension target that renders when a pos.cart.line-item-details.action.render
target calls for it
Was this section helpful?
Cart Line Item details action
import React from 'react';
import {
Text,
Screen,
ScrollView,
Navigator,
reactExtension,
useApi,
} from '@shopify/ui-extensions-react/point-of-sale';
const Modal = () => {
const api = useApi<'pos.cart.line-item-details.action.render'>();
return (
<Navigator>
<Screen name="CartLineItem" title="Cart Line Item">
<ScrollView>
<Text>{`Title for this line item: ${api.cartLineItem.title}`}</Text>
</ScrollView>
</Screen>
</Navigator>
);
};
export default reactExtension(
'pos.cart.line-item-details.action.render',
() => <Modal />,
);
examples
Cart Line Item details action
React
import React from 'react'; import { Text, Screen, ScrollView, Navigator, reactExtension, useApi, } from '@shopify/ui-extensions-react/point-of-sale'; const Modal = () => { const api = useApi<'pos.cart.line-item-details.action.render'>(); return ( <Navigator> <Screen name="CartLineItem" title="Cart Line Item"> <ScrollView> <Text>{`Title for this line item: ${api.cartLineItem.title}`}</Text> </ScrollView> </Screen> </Navigator> ); }; export default reactExtension( 'pos.cart.line-item-details.action.render', () => <Modal />, );
TS
import { Navigator, Screen, ScrollView, Text, extension, } from '@shopify/ui-extensions/point-of-sale'; export default extension( 'pos.cart.line-item-details.action.render', (root, api) => { const navigator = root.createComponent(Navigator); const screen = root.createComponent(Screen, { name: 'CartLineItem', title: 'Cart Line Item', }); const scrollView = root.createComponent(ScrollView); const text = root.createComponent(Text); text.append(`Title for this line item: ${api.cartLineItem.title}`); scrollView.append(text); screen.append(scrollView); navigator.append(screen); root.append(navigator); }, );