vue-instantsearch 4.2.0 → 4.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +9 -0
- package/package.json +2 -2
- package/src/components/DynamicWidgets.js +10 -0
- package/src/components/__tests__/DynamicWidgets.js +45 -0
- package/vue2/cjs/index.js +1 -1
- package/vue2/cjs/index.js.map +1 -1
- package/vue2/es/package.json.js +1 -1
- package/vue2/es/src/components/DynamicWidgets.js +1 -1
- package/vue2/es/src/components/DynamicWidgets.js.map +1 -1
- package/vue2/umd/index.js +1 -1
- package/vue2/umd/index.js.map +1 -1
- package/vue3/cjs/index.js +1 -1
- package/vue3/cjs/index.js.map +1 -1
- package/vue3/es/package.json.js +1 -1
- package/vue3/es/src/components/DynamicWidgets.js +1 -1
- package/vue3/es/src/components/DynamicWidgets.js.map +1 -1
- package/vue3/umd/index.js +1 -1
- package/vue3/umd/index.js.map +1 -1
package/vue2/es/package.json.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var r="4.
|
|
1
|
+
var r="4.3.0";export{r as version};
|
|
2
2
|
//# sourceMappingURL=package.json.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{createSuitMixin as t}from"../mixins/suit.js";import"vue";import{renderCompat as
|
|
1
|
+
import{createSuitMixin as t}from"../mixins/suit.js";import"vue";import{renderCompat as e,getDefaultSlot as i}from"../util/vue-compat/index-2.js";import{createWidgetMixin as r}from"../mixins/widget.js";import{connectDynamicWidgets as s}from"instantsearch.js/es/connectors";import{_objectSpread as n}from"../util/polyfills.js";export default{name:"AisDynamicWidgets",mixins:[r({connector:s}),t({name:"DynamicWidgets"})],props:{transformItems:{type:Function,default:void 0},facets:{type:Array,default:void 0},maxValuesPerFacet:{type:Number,default:void 0}},render:e(function(t){var e=this,r=new Map;if((i(this)||[]).forEach(function(i){var s=function t(e){var i,r=e.componentOptions&&e.componentOptions.propsData;if(r){if(r.attribute)return r.attribute;if(Array.isArray(r.attributes))return r.attributes[0]}if(i=e.componentOptions&&e.componentOptions.children?e.componentOptions.children:e.children,Array.isArray(i))return i.reduce(function(e,i){return e||t(i)},void 0)}(i);s&&r.set(s,t("div",{key:s,class:[e.suit("widget")]},[i]))}),!this.state){var s=[];return r.forEach(function(t){return s.push(t)}),t("div",n({class:[this.suit()]},{attrs:{hidden:!0}}),s)}return t("div",{class:[this.suit()]},this.state.attributesToRender.map(function(t){return r.get(t)}))}),computed:{widgetParams:function(){return{transformItems:this.transformItems,facets:this.facets,maxValuesPerFacet:this.maxValuesPerFacet,widgets:[]}}}};
|
|
2
2
|
//# sourceMappingURL=DynamicWidgets.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DynamicWidgets.js","sources":["../../../../src/components/DynamicWidgets.js"],"sourcesContent":["import { createWidgetMixin } from '../mixins/widget';\nimport { connectDynamicWidgets } from 'instantsearch.js/es/connectors';\nimport { createSuitMixin } from '../mixins/suit';\nimport { _objectSpread } from '../util/polyfills';\nimport { isVue3, renderCompat, getDefaultSlot } from '../util/vue-compat';\n\nfunction getWidgetAttribute(vnode) {\n const props = isVue3\n ? vnode.props\n : vnode.componentOptions && vnode.componentOptions.propsData;\n if (props) {\n if (props.attribute) {\n return props.attribute;\n }\n if (Array.isArray(props.attributes)) {\n return props.attributes[0];\n }\n }\n\n let children;\n if (isVue3) {\n children =\n vnode.children && vnode.children.default && vnode.children.default();\n } else {\n children =\n vnode.componentOptions && vnode.componentOptions.children\n ? vnode.componentOptions.children\n : vnode.children;\n }\n\n if (Array.isArray(children)) {\n // return first child with a truthy attribute\n return children.reduce(\n (acc, curr) => acc || getWidgetAttribute(curr),\n undefined\n );\n }\n\n return undefined;\n}\n\nexport default {\n name: 'AisDynamicWidgets',\n mixins: [\n createWidgetMixin({ connector: connectDynamicWidgets }),\n createSuitMixin({ name: 'DynamicWidgets' }),\n ],\n props: {\n transformItems: {\n type: Function,\n default: undefined,\n },\n },\n render: renderCompat(function(h) {\n const components = new Map();\n\n (getDefaultSlot(this) || []).forEach(vnode => {\n const attribute = getWidgetAttribute(vnode);\n if (attribute) {\n components.set(\n attribute,\n h('div', { key: attribute, class: [this.suit('widget')] }, [vnode])\n );\n }\n });\n\n // by default, render everything, but hidden so that the routing doesn't disappear\n if (!this.state) {\n const allComponents = [];\n components.forEach(component => allComponents.push(component));\n\n return h(\n 'div',\n _objectSpread(\n {\n class: [this.suit()],\n },\n { attrs: { hidden: true } }\n ),\n allComponents\n );\n }\n\n return h(\n 'div',\n { class: [this.suit()] },\n this.state.attributesToRender.map(attribute => components.get(attribute))\n );\n }),\n computed: {\n widgetParams() {\n return {\n transformItems: this.transformItems,\n // we do not pass \"widgets\" to the connector, since Vue is in charge of rendering\n widgets: [],\n };\n },\n },\n};\n"],"names":["name","mixins","createWidgetMixin","connector","connectDynamicWidgets","createSuitMixin","props","transformItems","type","Function","default","undefined","render","renderCompat","h","components","Map","getDefaultSlot","this","forEach","vnode","const","attribute","getWidgetAttribute","children","componentOptions","propsData","
|
|
1
|
+
{"version":3,"file":"DynamicWidgets.js","sources":["../../../../src/components/DynamicWidgets.js"],"sourcesContent":["import { createWidgetMixin } from '../mixins/widget';\nimport { connectDynamicWidgets } from 'instantsearch.js/es/connectors';\nimport { createSuitMixin } from '../mixins/suit';\nimport { _objectSpread } from '../util/polyfills';\nimport { isVue3, renderCompat, getDefaultSlot } from '../util/vue-compat';\n\nfunction getWidgetAttribute(vnode) {\n const props = isVue3\n ? vnode.props\n : vnode.componentOptions && vnode.componentOptions.propsData;\n if (props) {\n if (props.attribute) {\n return props.attribute;\n }\n if (Array.isArray(props.attributes)) {\n return props.attributes[0];\n }\n }\n\n let children;\n if (isVue3) {\n children =\n vnode.children && vnode.children.default && vnode.children.default();\n } else {\n children =\n vnode.componentOptions && vnode.componentOptions.children\n ? vnode.componentOptions.children\n : vnode.children;\n }\n\n if (Array.isArray(children)) {\n // return first child with a truthy attribute\n return children.reduce(\n (acc, curr) => acc || getWidgetAttribute(curr),\n undefined\n );\n }\n\n return undefined;\n}\n\nexport default {\n name: 'AisDynamicWidgets',\n mixins: [\n createWidgetMixin({ connector: connectDynamicWidgets }),\n createSuitMixin({ name: 'DynamicWidgets' }),\n ],\n props: {\n transformItems: {\n type: Function,\n default: undefined,\n },\n facets: {\n type: Array,\n default: undefined,\n },\n maxValuesPerFacet: {\n type: Number,\n default: undefined,\n },\n },\n render: renderCompat(function(h) {\n const components = new Map();\n\n (getDefaultSlot(this) || []).forEach(vnode => {\n const attribute = getWidgetAttribute(vnode);\n if (attribute) {\n components.set(\n attribute,\n h('div', { key: attribute, class: [this.suit('widget')] }, [vnode])\n );\n }\n });\n\n // by default, render everything, but hidden so that the routing doesn't disappear\n if (!this.state) {\n const allComponents = [];\n components.forEach(component => allComponents.push(component));\n\n return h(\n 'div',\n _objectSpread(\n {\n class: [this.suit()],\n },\n { attrs: { hidden: true } }\n ),\n allComponents\n );\n }\n\n return h(\n 'div',\n { class: [this.suit()] },\n this.state.attributesToRender.map(attribute => components.get(attribute))\n );\n }),\n computed: {\n widgetParams() {\n return {\n transformItems: this.transformItems,\n facets: this.facets,\n maxValuesPerFacet: this.maxValuesPerFacet,\n // we do not pass \"widgets\" to the connector, since Vue is in charge of rendering\n widgets: [],\n };\n },\n },\n};\n"],"names":["name","mixins","createWidgetMixin","connector","connectDynamicWidgets","createSuitMixin","props","transformItems","type","Function","default","undefined","facets","Array","maxValuesPerFacet","Number","render","renderCompat","h","components","Map","getDefaultSlot","this","forEach","vnode","const","attribute","getWidgetAttribute","children","componentOptions","propsData","isArray","attributes","reduce","acc","curr","set","key","class","suit","state","allComponents","component","push","_objectSpread","attrs","hidden","attributesToRender","map","get","computed","widgetParams","widgets"],"mappings":"mVAyCe,CACbA,KAAM,oBACNC,OAAQ,CACNC,EAAkB,CAAEC,UAAWC,IAC/BC,EAAgB,CAAEL,KAAM,oBAE1BM,MAAO,CACLC,eAAgB,CACdC,KAAMC,SACNC,aAASC,GAEXC,OAAQ,CACNJ,KAAMK,MACNH,aAASC,GAEXG,kBAAmB,CACjBN,KAAMO,OACNL,aAASC,IAGbK,OAAQC,EAAa,SAASC,cACtBC,EAAa,IAAIC,IAavB,IAXCC,EAAeC,OAAS,IAAIC,iBAAQC,GACnCC,IAAMC,EA3DZ,SAASC,EAAmBH,GAC1BC,IAYIG,EAZEtB,EAEFkB,EAAMK,kBAAoBL,EAAMK,iBAAiBC,UACrD,GAAIxB,EAAO,CACT,GAAIA,EAAMoB,UACR,OAAOpB,EAAMoB,UAEf,GAAIb,MAAMkB,QAAQzB,EAAM0B,YACtB,OAAO1B,EAAM0B,WAAW,GAe5B,GANEJ,EACEJ,EAAMK,kBAAoBL,EAAMK,iBAAiBD,SAC7CJ,EAAMK,iBAAiBD,SACvBJ,EAAMI,SAGVf,MAAMkB,QAAQH,GAEhB,OAAOA,EAASK,gBACbC,EAAKC,UAASD,GAAOP,EAAmBQ,SACzCxB,GA+BkBgB,CAAmBH,GACjCE,GACFP,EAAWiB,IACTV,EACAR,EAAE,MAAO,CAAEmB,IAAKX,EAAWY,MAAO,CAAChB,EAAKiB,KAAK,YAAc,CAACf,QAM7DF,KAAKkB,MAAO,CACff,IAAMgB,EAAgB,GAGtB,OAFAtB,EAAWI,iBAAQmB,UAAaD,EAAcE,KAAKD,KAE5CxB,EACL,MACA0B,EACE,CACEN,MAAO,CAAChB,KAAKiB,SAEf,CAAEM,MAAO,CAAEC,QAAQ,KAErBL,GAIJ,OAAOvB,EACL,MACA,CAAEoB,MAAO,CAAChB,KAAKiB,SACfjB,KAAKkB,MAAMO,mBAAmBC,aAAItB,UAAaP,EAAW8B,IAAIvB,QAGlEwB,SAAU,CACRC,wBACE,MAAO,CACL5C,eAAgBe,KAAKf,eACrBK,OAAQU,KAAKV,OACbE,kBAAmBQ,KAAKR,kBAExBsC,QAAS"}
|