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. That's take a look what can <yauction-product-picker /> do ?

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 <yauction-product-picker />'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 <yec-product-pick /> status.
limit Number Getter for fetch uther API parameter > limit.

Event

Event Signature Description
ypp-selected-change Fired when <yauction-product-picker /> selected product change.
ypp-submit Fired when user press <yauction-product-picker /> > submit button. Once user selected products, callBack function could gather these product ids through event.detail.selectedProducts.
ypp-close Fired when user press <yauction-product-picker /> > close button.

Reference