woocommerce/plugins/woocommerce-blocks/assets/js/base/components/shipping-rates-control/package.js

87 lines
2.1 KiB
JavaScript
Raw Normal View History

/**
* External dependencies
*/
import PropTypes from 'prop-types';
import { _n, sprintf } from '@wordpress/i18n';
import { Fragment } from '@wordpress/element';
import { decodeEntities } from '@wordpress/html-entities';
import Label from '@woocommerce/base-components/label';
/**
* Internal dependencies
*/
import PackageOptions from './package-options';
import './style.scss';
const Package = ( {
className,
noResultsMessage,
onChange,
renderOption,
selected,
shippingRate,
showItems,
} ) => {
return (
<Fragment>
<PackageOptions
className={ className }
noResultsMessage={ noResultsMessage }
onChange={ onChange }
options={ shippingRate.shipping_rates }
renderOption={ renderOption }
selected={ selected }
/>
{ showItems && (
<ul className="wc-block-shipping-rates-control__package-items">
{ Object.values( shippingRate.items ).map( ( v ) => {
const name = decodeEntities( v.name );
const quantity = v.quantity;
return (
<li
key={ name }
className="wc-block-shipping-rates-control__package-item"
>
<Label
label={ `${ name } ×${ quantity }` }
screenReaderLabel={ sprintf(
// translators: %s name of the product (ie: Sunglasses), %d number of units in the current cart package
_n(
'%s (%d unit)',
'%s (%d units)',
quantity,
'woo-gutenberg-products-block'
),
name,
quantity
) }
/>
</li>
);
} ) }
</ul>
) }
</Fragment>
);
};
Package.propTypes = {
onChange: PropTypes.func.isRequired,
renderOption: PropTypes.func.isRequired,
shippingRate: PropTypes.shape( {
shipping_rates: PropTypes.arrayOf( PropTypes.object ).isRequired,
items: PropTypes.objectOf(
PropTypes.shape( {
name: PropTypes.string.isRequired,
quantity: PropTypes.number.isRequired,
} ).isRequired
).isRequired,
} ).isRequired,
className: PropTypes.string,
noResultsMessage: PropTypes.string,
selected: PropTypes.string,
showItems: PropTypes.bool,
};
export default Package;