yauction-product-picker
v1.0.2
Published
To display specific promotion module, users might like to pick products to list by themselves. That's why I design <yauction-product-picker /> to fulfill this request. With <yauction-product-picker />, users could search products by keyword & category eas
Downloads
4
Maintainers
Readme
YAuction Product Picker
To display specific promotion module, users might like to pick products to list by themselves. That's why I design <yauction-product-picker /> to fulfill this request. With <yauction-product-picker />, users could search products by keyword & category easily. Besides that, <yauction-product-picker /> also provide property and method to switch seller role and setting. Infinite scroll feature has already built with it and user could browse product cells smoothly.
Basic Usage
<yauction-product-picker /> is a web component. All we need to do is put the required script into your HTML document. Then follow 's html structure and everything will be all set.
- Required Script
<script
type="module"
src="https://your-domain/wc-yauction-product-picker.js"
</script>
- Structure
Put <yauction-product-picker /> into HTML document. It will have different functions and looks with attribute mutation.
<yauction-product-picker>
<script type="application/json">
{
"storeid": "Y0174493470", // store id
"maxcount": 10, // max select count
"l10n": {
// localization
"placeholder": "請輸入關鍵字搜尋商品",
"selectCategory": "請選擇分類",
"all": "全部商品",
"submit": "確定選取"
},
"params": {
// params which uther needs
"spaceId": "2092115381",
"sort": "launchedTime"
}
}
</script>
</yauction-product-picker>
Otherwise, developers could also choose remoteconfig to fetch config for <yauction-product-picker />.
<yauction-product-picker
remoteconfig="https://617751a89c328300175f58b7.mockapi.io/api/v1/yauctionProductPicker"
...
></yauction-product-picker>
JavaScript Instantiation
<yauction-product-picker /> could also use JavaScript to create DOM element. Here comes some examples.
<script type="module">
import { YauctionProductPicker } from 'https://your-domain/wc-yauction-product-picker.js';
//use DOM api
const nodeA = document.createElement('yauction-product-picker');
document.body.appendChild(nodeA);
nodeA.storid = '...';
// new instance with Class
const nodeB = new YauctionProductPicker();
document.body.appendChild(nodeB);
nodeB.storid = '...';
// new instance with Class & default config
const config = {
storid: '...',
...
};
const nodeC = new YauctionProductPicker(config);
document.body.appendChild(nodeC);
</script>
Style Customization
<yauction-product-picker /> uses CSS variables to hook some action elements' looks. That means developer could easy change it into the looks you like.
<style>
yauction-product-picker {
--yauction-product-picker-remove-bgc: #e1e1e1;
--yauction-product-picker-icon-close: url() no-repeat 50% 50%/1.5em auto;
--yauction-product-picker-icon-search: url() no-repeat calc(var(--height) / 2) 50%/var(--icon-size) auto;
--yauction-product-picker-icon-arrow-down: url() transparent no-repeat calc(100% - 1.25em + 14px) 50% /20px auto;
--yauction-product-picker-icon-remove: url() var(--remove-bgc) no-repeat 50% 50% /80% auto;
--yauction-product-picker-logo: url() #fcda19 no-repeat 50% 50%/94% auto;
--yauction-product-picker-card-min-width: 180px;
--yauction-product-picker-close-bgc: transparent;
--yauction-product-picker-hover: #e1e1e1;
--yauction-product-picker-input-bgc: #efefef;
--yauction-product-picker-input-color: #000;
--yauction-product-picker-loader-color: #b0b9b1;
--yauction-product-picker-text-selected: '已挑選';
--yauction-product-picker-submit-bgc: #3abfba;
--yauction-product-picker-submit-border-color: #3abfba;
--yauction-product-picker-submit-text-color: #fff;
}
</style>
Attributes
<yauction-product-picker /> supports some attributes to let it become more convenience & useful.
- storeid
Set store id then user could browse its product listings. When storeid changed, <yauction-product-picker /> will auto fetch its categories
.
<yauction-product-picker
storeid="Y0174493470"
...
></yauction-product-picker>
- maxcount
Set max select count. Once user reach this count they can not pick product cell anymore until unpick product. (default is 10
)
<yauction-product-picker
maxcount="10"
...
></yauction-product-picker>
- l10n
Set localization for UI display. It combines several keys that's why it accept JSON string only.
<yauction-product-picker
l10n='{"placeholder":"請輸入關鍵字搜尋商品","selectCategory":"請選擇分類","all":"全部商品","submit":"確定選取"}'
...
></yauction-product-picker>
- params
Set parameters for uther API fetch.(spaceId
can not be null)
<yauction-product-picker
params='{"spaceId":"2092115381","sort":"launchedTime"}'
...
></yauction-product-picker>
Methods
Here comes methods which <yauction-product-picker /> supported.
- show
Display <yauction-product-picker />>. This method accepts two parameter: productIds, maxcount. Both of them are optional.
<script>
const picker = document.querySelector('yauction-product-picker');
picker.show(
{
productIds: [
'101056169643',
'101023641341',
'101011522685'
],
maxcount: 20
}
);
</script>
- close
Turn off <yauction-product-picker />.
<script>
const picker = document.querySelector('yauction-product-picker');
picker.close();
</script>
Properties
| Property Name | Type | Description | | ----------- | ----------- | ----------- | | storeid | String | Getter / Setter for store id. | | maxcount | Number | Getter / Setter for max select count. | | params | Object | Getter / Setter for parameters which fetch uther API should be attached. | | l10n | Object | Getter / Setter localization for UI display. | | active | Boolean | Getter for status. | | limit | Number | Getter for fetch uther API parameter > limit. |
Events
| Event Signature | Description |
| ----------- | ----------- |
| ypp-selected-change | Fired when selected product change. |
| ypp-submit | Fired when user press > submit button. Once user selected products, callBack function could gather these product ids through event.detail.selectedProducts
. |
| ypp-close | Fired when user press > close button. |