@abi-software/map-side-bar 1.5.2 → 1.5.3
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/dist/map-side-bar.common.js +40 -27
- package/dist/map-side-bar.common.js.map +1 -1
- package/dist/map-side-bar.css +1 -1
- package/dist/map-side-bar.umd.js +40 -27
- package/dist/map-side-bar.umd.js.map +1 -1
- package/dist/map-side-bar.umd.min.js +1 -1
- package/dist/map-side-bar.umd.min.js.map +1 -1
- package/package.json +1 -1
- package/src/components/SearchHistory.vue +2 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["webpack://map-side-bar/webpack/bootstrap","webpack://map-side-bar/external \"element-ui/lib/pagination\"","webpack://map-side-bar/external \"core-js/modules/es.symbol.iterator\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/pagination.css\"","webpack://map-side-bar/external \"@abi-software/gallery/src/main-bundle.js\"","webpack://map-side-bar/./src/components/SearchHistory.vue?c814","webpack://map-side-bar/external \"core-js/modules/es.parse-int\"","webpack://map-side-bar/external \"element-ui/lib/select\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/select.css\"","webpack://map-side-bar/external \"core-js/modules/es.array.for-each\"","webpack://map-side-bar/./src/components/SidebarContent.vue?56f4","webpack://map-side-bar/external \"core-js/modules/es.array.concat\"","webpack://map-side-bar/external \"core-js/modules/web.dom-collections.iterator\"","webpack://map-side-bar/external \"core-js/modules/es.object.keys\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/button.css\"","webpack://map-side-bar/external \"core-js/modules/web.url\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/loading.css\"","webpack://map-side-bar/./src/components/ImageGallery.vue?bd5b","webpack://map-side-bar/./src/components/DatasetCard.vue?40b1","webpack://map-side-bar/external \"element-ui/lib/drawer\"","webpack://map-side-bar/./src/components/ImageGallery.vue?140b","webpack://map-side-bar/external \"core-js/modules/es.array.join\"","webpack://map-side-bar/./src/components/SearchFilters.vue?ccce","webpack://map-side-bar/external \"@abi-software/svg-sprite\"","webpack://map-side-bar/external \"core-js/modules/es.object.get-own-property-descriptors\"","webpack://map-side-bar/external \"core-js/modules/es.string.split\"","webpack://map-side-bar/external \"core-js/modules/es.set\"","webpack://map-side-bar/external \"core-js/modules/es.array.filter\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/card.css\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/drawer.css\"","webpack://map-side-bar/./src/components/SearchFilters.vue?1ef4","webpack://map-side-bar/external \"core-js/modules/es.symbol.description\"","webpack://map-side-bar/external \"core-js/modules/es.regexp.exec\"","webpack://map-side-bar/external \"element-ui/lib/button\"","webpack://map-side-bar/external \"core-js/modules/es.regexp.to-string\"","webpack://map-side-bar/external \"core-js/modules/es.symbol\"","webpack://map-side-bar/external \"core-js/modules/es.array.slice\"","webpack://map-side-bar/external \"core-js/modules/es.object.get-own-property-descriptor\"","webpack://map-side-bar/external \"element-ui/lib/cascader\"","webpack://map-side-bar/./src/components/DatasetCard.vue?59a6","webpack://map-side-bar/external \"element-ui/lib/locale/lang/en\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/cascader.css\"","webpack://map-side-bar/external \"core-js/modules/es.array.sort\"","webpack://map-side-bar/external \"core-js/modules/es.number.constructor\"","webpack://map-side-bar/external \"regenerator-runtime/runtime\"","webpack://map-side-bar/./src/components/SearchHistory.vue?c928","webpack://map-side-bar/external \"core-js/modules/es.array.splice\"","webpack://map-side-bar/external \"element-ui/lib/locale\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/option.css\"","webpack://map-side-bar/external \"core-js/modules/es.promise\"","webpack://map-side-bar/external \"core-js/modules/es.object.to-string\"","webpack://map-side-bar/external \"algoliasearch\"","webpack://map-side-bar/external \"vue\"","webpack://map-side-bar/external \"core-js/modules/es.array.iterator\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/icon.css\"","webpack://map-side-bar/./src/components/Tabs.vue?3e70","webpack://map-side-bar/external \"core-js/modules/es.string.iterator\"","webpack://map-side-bar/external \"element-ui/lib/popover\"","webpack://map-side-bar/external \"core-js/modules/es.map\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/base.css\"","webpack://map-side-bar/external \"core-js/modules/es.array.flat\"","webpack://map-side-bar/./assets/missing-image.svg","webpack://map-side-bar/external \"@abi-software/gallery/src/mixins/GalleryHelpers\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/popover.css\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/input.css\"","webpack://map-side-bar/external \"core-js/modules/es.array.includes\"","webpack://map-side-bar/external \"element-ui/lib/loading\"","webpack://map-side-bar/external \"core-js/modules/es.array.find-index\"","webpack://map-side-bar/external \"element-ui/lib/tag\"","webpack://map-side-bar/./src/components/BadgesGroup.vue?b201","webpack://map-side-bar/external \"element-ui/lib/card\"","webpack://map-side-bar/external \"element-ui/lib/icon\"","webpack://map-side-bar/external \"core-js/modules/es.object.assign\"","webpack://map-side-bar/./src/components/SideBar.vue?4c29","webpack://map-side-bar/external \"core-js/modules/es.function.name\"","webpack://map-side-bar/external \"core-js/modules/web.dom-collections.for-each\"","webpack://map-side-bar/external \"core-js/modules/es.string.search\"","webpack://map-side-bar/external \"core-js/modules/es.string.replace\"","webpack://map-side-bar/./src/components/SearchHistory.vue?4f9c","webpack://map-side-bar/external \"element-ui/lib/option\"","webpack://map-side-bar/./src/components/Tabs.vue?8d2a","webpack://map-side-bar/./src/components/BadgesGroup.vue?1918","webpack://map-side-bar/./src/components/SearchHistory.vue?4bed","webpack://map-side-bar/./src/components/SideBar.vue?0b7f","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/tag.css\"","webpack://map-side-bar/external \"core-js/modules/es.array.last-index-of\"","webpack://map-side-bar/external \"current-script-polyfill\"","webpack://map-side-bar/external \"core-js/modules/es.array.from\"","webpack://map-side-bar/external \"element-ui/lib/input\"","webpack://map-side-bar/./src/components/SidebarContent.vue?a5ca","webpack://map-side-bar/external \"core-js/modules/es.object.entries\"","webpack://map-side-bar/external \"core-js/modules/es.array.unscopables.flat\"","webpack://map-side-bar/external \"core-js/modules/es.array.map\"","webpack://map-side-bar/external \"core-js/modules/es.promise.finally\"","webpack://map-side-bar/./node_modules/@vue/cli-service/lib/commands/build/setPublicPath.js","webpack://map-side-bar/./src/components/SideBar.vue?2b06","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/defineProperty.js","webpack://map-side-bar/./src/components/SidebarContent.vue?b752","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/iterableToArray.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","webpack://map-side-bar/./src/components/SearchFilters.vue?1fa8","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/toArray.js","webpack://map-side-bar/src/components/Cascader.vue","webpack://map-side-bar/./src/components/Cascader.vue?9729","webpack://map-side-bar/./node_modules/vue-loader/lib/runtime/componentNormalizer.js","webpack://map-side-bar/./src/components/Cascader.vue","webpack://map-side-bar/./src/components/species-map.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/classCallCheck.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/createClass.js","webpack://map-side-bar/./src/algolia/algolia.js","webpack://map-side-bar/./src/algolia/utils.js","webpack://map-side-bar/src/components/SearchFilters.vue","webpack://map-side-bar/./src/components/SearchFilters.vue?8079","webpack://map-side-bar/./src/components/SearchFilters.vue","webpack://map-side-bar/./src/components/SearchHistory.vue?f86e","webpack://map-side-bar/./src/components/EventBus.js","webpack://map-side-bar/src/components/SearchHistory.vue","webpack://map-side-bar/./src/components/SearchHistory.vue?c6dc","webpack://map-side-bar/./src/components/SearchHistory.vue","webpack://map-side-bar/./src/components/DatasetCard.vue?e0ad","webpack://map-side-bar/./src/components/BadgesGroup.vue?23a5","webpack://map-side-bar/src/components/BadgesGroup.vue","webpack://map-side-bar/./src/components/BadgesGroup.vue?6a7e","webpack://map-side-bar/./src/components/BadgesGroup.vue","webpack://map-side-bar/./src/components/ImageGallery.vue?c32c","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/slicedToArray.js","webpack://map-side-bar/src/mixins/S3Bucket.vue","webpack://map-side-bar/./src/mixins/S3Bucket.vue?faba","webpack://map-side-bar/./src/mixins/S3Bucket.vue","webpack://map-side-bar/src/components/ImageGallery.vue","webpack://map-side-bar/./src/components/ImageGallery.vue?b8b4","webpack://map-side-bar/./src/components/ImageGallery.vue","webpack://map-side-bar/src/components/DatasetCard.vue","webpack://map-side-bar/./src/components/DatasetCard.vue?d021","webpack://map-side-bar/./src/components/DatasetCard.vue","webpack://map-side-bar/src/components/SidebarContent.vue","webpack://map-side-bar/./src/components/SidebarContent.vue?7e01","webpack://map-side-bar/./src/components/SidebarContent.vue","webpack://map-side-bar/./src/components/Tabs.vue?1923","webpack://map-side-bar/src/components/Tabs.vue","webpack://map-side-bar/./src/components/Tabs.vue?3d38","webpack://map-side-bar/./src/components/Tabs.vue","webpack://map-side-bar/src/components/SideBar.vue","webpack://map-side-bar/./src/components/SideBar.vue?b259","webpack://map-side-bar/./src/components/SideBar.vue","webpack://map-side-bar/./src/components/index.js","webpack://map-side-bar/./node_modules/@vue/cli-service/lib/commands/build/entry-lib-no-default.js","webpack://map-side-bar/external \"core-js/modules/es.string.includes\"","webpack://map-side-bar/external \"core-js/modules/es.array.find\""],"names":["asyncGeneratorStep","gen","resolve","reject","_next","_throw","key","arg","info","value","error","done","Promise","then","_asyncToGenerator","fn","self","args","arguments","apply","err","undefined","_defineProperty","obj","Object","defineProperty","enumerable","configurable","writable","_arrayWithoutHoles","arr","Array","isArray","i","arr2","length","_iterableToArray","iter","Symbol","iterator","prototype","toString","call","from","_nonIterableSpread","TypeError","_toConsumableArray","arrayWithoutHoles","iterableToArray","nonIterableSpread","_arrayWithHoles","_nonIterableRest","_toArray","arrayWithHoles","nonIterableRest","_classCallCheck","instance","Constructor","_defineProperties","target","props","descriptor","_createClass","protoProps","staticProps","AlgoliaClient","algoliaId","algoliaKey","PENNSIEVE_API_LOCATION","client","algoliasearch","anatomyFacetLabels","ALGOLIA_INDEX","index","initIndex","propPathMapping","map","Map","entries","facetPropPaths","keys","facetData","facetId","search","sortFacetValuesBy","facets","response","facetPropPath","children","responseFacets","responseFacetChildren","facet","push","label","id","get","discoverId","fetch","r","json","dataset","version","doi","discoverIds","promiseList","_discoverAllDois","all","values","flat","results","newResults","newResult","res","item","curie","split","name","description","updated","pennsieve","updatedAt","publishDate","datasetId","objectID","detailsReady","hits","foundKeyWords","foundLabels","uniqueLabels","uniqueKeywords","forEach","hit","keywords","keywordObj","keyword","toUpperCase","includes","_processUberonURL","anatomy","organ","Set","url","ub","pop","replace","filter","query","hitsperPage","page","hitsPerPage","filters","attributesToHighlight","attributesToRetrieve","searchData","items","_processResultsForCards","total","nbHits","identifier","dois","anatomyAsUberons","_processAnatomy","facetPropPathMapping","shownFilters","getFilters","selectedFacetArray","f","removeShowAllFacets","facetsToBool","orFilters","andFilters","AND","substring","lastIndexOf","join","facetArray","EventBus","Vue","_iterableToArrayLimit","_arr","_n","_d","_e","_i","_s","next","_slicedToArray","iterableToArrayLimit"],"mappings":";;QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;AClFA,sD;;;;;;;ACAA,+D;;;;;;;ACAA,sE;;;;;;;ACAA,qE;;;;;;;;ACAA;AAAA;AAAA;AAAgiB,CAAgB,qkBAAG,EAAC,C;;;;;;;ACApjB,yD;;;;;;;ACAA,kD;;;;;;;ACAA,kE;;;;;;;ACAA,8D;;;;;;;;ACAA;AAAA;AAAA;AAAyjB,CAAgB,8lBAAG,EAAC,C;;;;;;;ACA7kB,4D;;;;;;;ACAA,yE;;;;;;;ACAA,2D;;;;;;;ACAA,kE;;;;;;;ACAA,oD;;;;;;;ACAA,mE;;;;;;;ACAA,uC;;;;;;;ACAA,uC;;;;;;;ACAA,kD;;;;;;;;ACAA;AAAA;AAAA;AAAujB,CAAgB,4lBAAG,EAAC,C;;;;;;;ACA3kB,0D;;;;;;;;ACAA;AAAA;AAAA;AAAwjB,CAAgB,6lBAAG,EAAC,C;;;;;;;ACA5kB,qD;;;;;;;ACAA,mF;;;;;;;ACAA,4D;;;;;;;ACAA,mD;;;;;;;ACAA,4D;;;;;;;ACAA,gE;;;;;;;ACAA,kE;;;;;;;ACAA,uC;;;;;;;ACAA,kE;;;;;;;ACAA,2D;;;;;;;ACAA,kD;;;;;;;ACAA,gE;;;;;;;ACAA,sD;;;;;;;ACAA,2D;;;;;;;ACAA,kF;;;;;;;ACAA,oD;;;;;;;;ACAA;AAAA;AAAA;AAAsjB,CAAgB,2lBAAG,EAAC,C;;;;;;;ACA1kB,0D;;;;;;;ACAA,oE;;;;;;;ACAA,0D;;;;;;;ACAA,kE;;;;;;;ACAA,wD;;;;;;;;ACAA;AAAA;AAAA;AAAwjB,CAAgB,6lBAAG,EAAC,C;;;;;;;ACA5kB,4D;;;;;;;ACAA,kD;;;;;;;ACAA,kE;;;;;;;ACAA,uD;;;;;;;ACAA,gE;;;;;;;ACAA,0C;;;;;;;ACAA,gC;;;;;;;ACAA,8D;;;;;;;ACAA,gE;;;;;;;;ACAA;AAAA;AAAA;AAA+iB,CAAgB,olBAAG,EAAC,C;;;;;;;ACAnkB,+D;;;;;;;ACAA,mD;;;;;;;ACAA,mD;;;;;;;ACAA,gE;;;;;;;ACAA,0D;;;;;;;ACAA,iBAAiB,qBAAuB,oC;;;;;;;ACAxC,4E;;;;;;;ACAA,mE;;;;;;;ACAA,iE;;;;;;;ACAA,8D;;;;;;;ACAA,mD;;;;;;;ACAA,gE;;;;;;;ACAA,+C;;;;;;;ACAA,uC;;;;;;;ACAA,gD;;;;;;;ACAA,gD;;;;;;;ACAA,6D;;;;;;;;ACAA;AAAA;AAAA;AAAkjB,CAAgB,ulBAAG,EAAC,C;;;;;;;ACAtkB,6D;;;;;;;ACAA,yE;;;;;;;ACAA,6D;;;;;;;ACAA,8D;;;;;;;ACAA,uC;;;;;;;ACAA,kD;;;;;;;ACAA,uC;;;;;;;;ACAA;AAAA;AAAA;AAAsjB,CAAgB,2lBAAG,EAAC,C;;;;;;;ACA1kB,uC;;;;;;;ACAA,uC;;;;;;;ACAA,+D;;;;;;;ACAA,mE;;;;;;;ACAA,oD;;;;;;;ACAA,0D;;;;;;;ACAA,iD;;;;;;;ACAA,uC;;;;;;;ACAA,8D;;;;;;;ACAA,sE;;;;;;;ACAA,yD;;;;;;;ACAA,+D;;;;;;;;;;;;;;;ACAA;;AAEA;AACA,MAAM,IAAuC;AAC7C,IAAI,mBAAO,CAAC,MAAyB;AACrC;;AAEA,MAAM,eAAC;AACP,OAAO,eAAC,sCAAsC,eAAC,GAAG,eAAC;AACnD,IAAI,qBAAuB,GAAG,eAAC;AAC/B;AACA;;AAEA;AACe,sDAAI;;;ACdnB,0BAA0B,aAAa,0BAA0B,wBAAwB,iBAAiB,gBAAgB,8BAA8B,2BAA2B,0BAA0B,UAAU,iCAAiC,6BAA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AAD,CAAtC,IAA+CwB,gBAAe,EAArE;AACD,C;;;;;;;;;;;;;;;;;;;;ACJD;AAGA;AACA,wBADA;AAEA,6BAFA;AAGA;AACA;AACA,sBAFA,gCAEA;AAAA,UACA,UADA,GACA,IADA,CACA,UADA;AAAA,UACA,QADA,GACA,IADA,CACA,QADA;AAAA,UACA,aADA,GACA,IADA,CACA,aADA;AAAA,UACA,SADA,GACA,IADA,CACA,SADA;AAAA,UACA,YADA,GACA,IADA,CACA,YADA;AAEA;AACA;;AACA;AAAA;AACA,oBADA;AAEA,uBAFA;AAGA,sDAHA;AAIA,yBAJA;AAKA;AALA;AAAA;;AAOA,4DACA;AACA;AACA,OAHA;;AAKA;AAAA,oCACA,WADA;AAAA,YACA,KADA;AAAA,YACA,IADA;;AAEA;AACA;;AACA;AACA;AACA;AACA,qBADA;AAEA,0CAFA;AAGA;AAHA;AAKA,WANA,MAMA;AACA;AAAA;AAAA;AACA;AACA;AACA;;AACA;AACA;AACA;AACA;AArCA;AAHA,G;;ACJkU,CAAgB,gHAAG,EAAC,C;;ACAtV;;AAEA;AACA;AACA;;AAEe;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,yBAAyB;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,qBAAqB;AACrB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;;AC5FA,IAAI,eAAM,EAAE,wBAAe;AACiC;AACL;;;AAGvD;AAC0F;AAC1F,gBAAgB,kBAAU;AAC1B,EAAE,2CAAM;AACR,EAAE,eAAM;AACR,EAAE,wBAAe;AACjB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CA;AACA;AACA,OAFA,MAEA;AACA;AACA;AACA,KAhDA;AAiDA;AACA;AACA;AACA;AACA,iDAFA,CAIA;;AACA;AAAA;AAAA;AAAA;AACA,gCADA;AAEA,sCAFA;AAGA,qCAHA;AAIA,sBAJA,CAIA;;AAJA;AAAA,WALA,CAYA;;AACA;AAAA;AAAA;AACA;AACA;AACA,mCADA;AAEA,sCAFA;AAGA,qCAHA;AAIA,sBAJA,CAIA;;AAJA;AAMA,SARA;AAWA,oCAxBA,CAwBA;;AAEA,6CA1BA,CA0BA;;AACA,qCA3BA,CA2BA;;AACA;AACA;AACA,KAjFA;AAkFA;AACA;AACA;AAAA;;AACA;AACA,6BACA,GADA,CACA;AAAA;AAAA,OADA,EAEA,QAFA,CAEA,IAFA,EAFA,CAKA;;AACA;AACA;AACA,2BAFA,CAGA;;AACA;AACA;AACA;AACA,SAPA,CAQA;;;AACA;AACA,kCADA,CAEA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA;AACA;AACA;AACA;AACA,+CACA,8EADA,KAEA;AACA,aANA,MAMA;AACA;AACA;AACA;AACA,WAXA,MAWA;AACA;AACA;AACA,SAjCA,CAkCA;;;AACA;AACA;AACA;AACA;AACA;AACA,eAFA,MAEA;AACA;AACA;AACA,aANA,MAMA;AACA;AACA;AACA,eAFA,MAEA;AACA;AACA;AACA,aANA,MAMA;AACA;AACA;AACA,WAhBA,MAgBA;AACA,SAlBA;AAmBA;;AACA;AACA,KAlJA;AAmJA;AACA;AACA;AACA;AACA,KAvJA;AAwJA;AACA;AACA,KA1JA;AA2JA;AAAA;;AACA;AACA;AACA;AACA;;AACA;AACA,2DACA;AACA,OAHA;AAIA,KApKA;AAqKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;;AACA;AACA;AACA;AACA,kBACA,eADA,EAEA,2DAFA;AAIA,SALA,EADA,CAQA;AACA;;AACA;AACA,kBACA,eADA,EAEA,2DAFA,EAGA,KAHA;AAKA,SANA;AAOA;AACA;AACA,KAlMA;AAmMA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAC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EA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA,qBADA;AAEA;AAAA;AAAA;AAAA,GAFA;AAGA;AACA;;;;AAIA;AACA,kBADA;AAEA;AAFA,KALA;AASA;AACA,kBADA;AAEA;AAFA;AATA,GAHA;AAiBA;AACA;AACA,4CADA;AAEA,kCAFA;AAGA,2BAHA;AAIA,mBAJA;AAKA,gBALA;AAMA,wBANA;AAOA,8BAPA;AAQA;AARA;AAUA,GA5BA;AA6BA;AACA;AACA;;AACA;AACA;AACA;AACA,SAFA,MAEA;AACA;AACA,SAFA,MAEA;AACA;AACA;AACA;;AACA;AACA,KAbA;AAcA;AACA;;AACA;AACA;AACA;AACA,SAFA,MAEA;AACA;AACA;AACA;;AACA;AACA;;AACA;AACA;AACA,SAFA,MAEA;AACA;AACA;;AACA;AACA;AACA,SAFA,MAEA;AACA;AACA;;AACA;AACA;;AAEA;AACA,KAvCA;AAwCA;AACA;AACA,KA1CA;AA2CA;AACA;AACA;AA7CA,GA7BA;AA4EA;AACA;AACA;AACA,KAHA;AAIA;AACA;AACA,KANA;AAOA;AACA;AACA,KATA;AAUA;AACA;AACA,KAZA;AAaA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA;AACA;AACA;;AACA;AACA;AACA;;AACA;AACA;AACA;;AACA;AACA;AACA,WAXA;;AAYA;AAAA;AAAA;AACA;AACA,OAnBA;AAoBA,KAnCA;AAoCA;AACA;AACA,yDAFA,CAEA;AACA,KAvCA;AAwCA;AACA;AACA,KA1CA;AA2CA;AAAA;;AACA;AACA;AACA;AACA;AACA;AACA,4HACA,IADA,CACA;AACA;AACA;AACA,WAFA,MAEA;AACA;AACA;AACA,SAPA,EAQA,IARA,CAQA;AACA;AACA;AACA;AACA;;AACA;;AACA;AACA,SAfA,EAgBA,KAhBA,CAgBA;AACA;AACA;AACA;AACA;AACA,SArBA;AAsBA;AAEA,KAzEA;AA0EA;AACA;AACA,KA5EA;AA6EA;AAAA;;AACA;AACA,wDAFA,CAGA;;AACA,sBACA,IADA,CACA;AAAA;AAAA,OADA,EAEA,IAFA,CAEA;AACA,sCACA;AACA,OALA;AAMA;AAvFA,GA5EA;AAqKA;AACA;AACA,GAvKA;AAwKA;AACA;AACA;AAAA;AACA;AACA;AAJA;AAxKA,G;;ACvDqU,CAAgB,sHAAG,EAAC,C;;;;;ACAnP;AACvC;AACL;AACsC;;;AAGhG;AAC0F;AAC1F,IAAI,qBAAS,GAAG,kBAAU;AAC1B,EAAE,8CAAM;AACR,EAAE,2DAAM;AACR,EAAE,oEAAe;AACjB;AACA;AACA;AACA;;AAEA;;AAEe,qEAAS,Q;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC+BxB;AACA;AAUA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iD,CAEA;AACA;;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gBACA,WADA;AAAA;AAAA;AAAA;;AAAA;AAAA,mBAEA,eAFA;;AAAA;AAEA,iBAFA;;AAAA,iBAGA,KAHA;AAAA;AAAA;AAAA;;AAAA,kBAIA,wBAJA;;AAAA;AAAA,kBAMA,mBANA;;AAAA;AAAA,6CASA,QATA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;;AAYA;AACA,iBADA;AAEA,gBAFA;AAGA,aAHA;AAIA,iBAJA;AAKA,YALA;AAMA,qBANA;AAOA,mBAPA;AAQA,SARA;AASA,cATA;AAUA,UAVA;AAWA,oBAXA;AAYA;AAZA;AAeA;AACA;AAAA;AAAA;AAAA;AAAA,GADA;AAEA,wBAFA;AAGA;AACA;AACA,mBADA;AAEA;AAFA,KADA;AAKA;AACA,mBADA;AAEA;AAFA,KALA;AASA;AACA,kBADA;AAEA;AAAA;AAAA;AAFA,KATA;AAaA;AACA,kBADA;AAEA;AAFA;AAbA,GAHA;AAqBA;AACA,WAAW,uDACX,UADA;AAEA;AACA,wBADA;AAEA,6BAFA;AAGA;AAHA,OAFA;AAOA;AAPA;AASA,GA/BA;AAgCA;AACA;AACA;AACA;AACA,uCADA;AAEA;AAFA;AAIA;AAPA,GAhCA;AAyCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAPA;AAQA;AAAA;AACA;AACA,iCAFA,CAGA;;AACA;AACA,wEADA,CAEA;AACA;AACA;;AACA,YACA,UACA,iBADA,IAEA,WAFA,IAGA,wBAJA,EAKA;AACA;AACA;AACA,SARA,MAQA;AACA;AACA;AACA;AACA,OAjBA,MAiBA;AACA;AACA;AACA;;AACA;AACA;AACA;AACA;AACA,KArCA;AAsCA;AACA;AACA;;AACA;AACA,uDACA;AACA;AACA,OANA,MAMA;AACA;AACA;AACA,SAFA,MAEA;AACA;AACA;AACA;AACA,KApDA;AAqDA;AACA;AACA;AACA,KAxDA;AAyDA;AACA;AACA;AACA;AACA;AACA,KA9DA;AA+DA;AAAA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAtEA;AAuEA;AACA;AACA;AACA;AACA;AACA,sBADA;AAEA;AAFA;AAIA,KA/EA;AAgFA,iBAhFA,yBAgFA,OAhFA,EAgFA;AAAA;;AAAA;AACA;AACA;AACA,yBACA,eADA,CACA,mBADA,EACA,KADA,EAEA,IAFA,CAEA;AACA;AACA,4BADA;AAEA;AAFA;AAIA,OAPA;AAQA,yBACA,MADA,CACA,mBADA,EACA,KADA,EACA,kBADA,EACA,SADA,EAEA,IAFA,CAEA;AACA;AACA;AACA;AACA;AACA;;AACA;;AACA;AACA,kCADA;AAEA;AAFA;;AAIA;AACA;AACA,mDAbA,CAcA;;AACA;AAAA;AAAA;AACA,OAlBA;AAmBA,KA9GA;AA+GA;AACA;AACA,KAjHA;AAkHA;AACA;AACA;AACA,KArHA;AAsHA;AACA;AACA;AACA,yBACA,YADA,EAEA,gBAFA,EAGA,kBAHA,EAIA,SAJA;AAMA,KA/HA;AAgIA;AACA;AAAA;AAAA;AACA;AACA,KAnIA;AAoIA;AAAA;;AACA;AACA;AACA;;AACA;AACA;;AACA;AACA;AACA;AAAA;AAAA,qBACA,IADA,CACA;AACA,8EACA;AACA;AACA,y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","file":"map-side-bar.common.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"fae3\");\n","module.exports = require(\"element-ui/lib/pagination\");","module.exports = require(\"core-js/modules/es.symbol.iterator\");","module.exports = require(\"element-ui/lib/theme-chalk/pagination.css\");","module.exports = require(\"@abi-software/gallery/src/main-bundle.js\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=style&index=1&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=style&index=1&lang=scss&\"","module.exports = require(\"core-js/modules/es.parse-int\");","module.exports = require(\"element-ui/lib/select\");","module.exports = require(\"element-ui/lib/theme-chalk/select.css\");","module.exports = require(\"core-js/modules/es.array.for-each\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SidebarContent.vue?vue&type=style&index=0&id=33c92dc7&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SidebarContent.vue?vue&type=style&index=0&id=33c92dc7&scoped=true&lang=scss&\"","module.exports = require(\"core-js/modules/es.array.concat\");","module.exports = require(\"core-js/modules/web.dom-collections.iterator\");","module.exports = require(\"core-js/modules/es.object.keys\");","module.exports = require(\"element-ui/lib/theme-chalk/button.css\");","module.exports = require(\"core-js/modules/web.url\");","module.exports = require(\"element-ui/lib/theme-chalk/loading.css\");","// extracted by mini-css-extract-plugin","// extracted by mini-css-extract-plugin","module.exports = require(\"element-ui/lib/drawer\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ImageGallery.vue?vue&type=style&index=0&id=31f0d189&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ImageGallery.vue?vue&type=style&index=0&id=31f0d189&scoped=true&lang=scss&\"","module.exports = require(\"core-js/modules/es.array.join\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchFilters.vue?vue&type=style&index=0&id=228b9f2c&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchFilters.vue?vue&type=style&index=0&id=228b9f2c&scoped=true&lang=scss&\"","module.exports = require(\"@abi-software/svg-sprite\");","module.exports = require(\"core-js/modules/es.object.get-own-property-descriptors\");","module.exports = require(\"core-js/modules/es.string.split\");","module.exports = require(\"core-js/modules/es.set\");","module.exports = require(\"core-js/modules/es.array.filter\");","module.exports = require(\"element-ui/lib/theme-chalk/card.css\");","module.exports = require(\"element-ui/lib/theme-chalk/drawer.css\");","// extracted by mini-css-extract-plugin","module.exports = require(\"core-js/modules/es.symbol.description\");","module.exports = require(\"core-js/modules/es.regexp.exec\");","module.exports = require(\"element-ui/lib/button\");","module.exports = require(\"core-js/modules/es.regexp.to-string\");","module.exports = require(\"core-js/modules/es.symbol\");","module.exports = require(\"core-js/modules/es.array.slice\");","module.exports = require(\"core-js/modules/es.object.get-own-property-descriptor\");","module.exports = require(\"element-ui/lib/cascader\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./DatasetCard.vue?vue&type=style&index=0&id=b08ebd76&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./DatasetCard.vue?vue&type=style&index=0&id=b08ebd76&scoped=true&lang=scss&\"","module.exports = require(\"element-ui/lib/locale/lang/en\");","module.exports = require(\"element-ui/lib/theme-chalk/cascader.css\");","module.exports = require(\"core-js/modules/es.array.sort\");","module.exports = require(\"core-js/modules/es.number.constructor\");","module.exports = require(\"regenerator-runtime/runtime\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=style&index=0&id=ca301f24&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=style&index=0&id=ca301f24&scoped=true&lang=scss&\"","module.exports = require(\"core-js/modules/es.array.splice\");","module.exports = require(\"element-ui/lib/locale\");","module.exports = require(\"element-ui/lib/theme-chalk/option.css\");","module.exports = require(\"core-js/modules/es.promise\");","module.exports = require(\"core-js/modules/es.object.to-string\");","module.exports = require(\"algoliasearch\");","module.exports = require(\"vue\");","module.exports = require(\"core-js/modules/es.array.iterator\");","module.exports = require(\"element-ui/lib/theme-chalk/icon.css\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Tabs.vue?vue&type=style&index=0&id=6bfde6c2&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Tabs.vue?vue&type=style&index=0&id=6bfde6c2&scoped=true&lang=scss&\"","module.exports = require(\"core-js/modules/es.string.iterator\");","module.exports = require(\"element-ui/lib/popover\");","module.exports = require(\"core-js/modules/es.map\");","module.exports = require(\"element-ui/lib/theme-chalk/base.css\");","module.exports = require(\"core-js/modules/es.array.flat\");","module.exports = __webpack_public_path__ + \"img/missing-image.1878d8b8.svg\";","module.exports = require(\"@abi-software/gallery/src/mixins/GalleryHelpers\");","module.exports = require(\"element-ui/lib/theme-chalk/popover.css\");","module.exports = require(\"element-ui/lib/theme-chalk/input.css\");","module.exports = require(\"core-js/modules/es.array.includes\");","module.exports = require(\"element-ui/lib/loading\");","module.exports = require(\"core-js/modules/es.array.find-index\");","module.exports = require(\"element-ui/lib/tag\");","// extracted by mini-css-extract-plugin","module.exports = require(\"element-ui/lib/card\");","module.exports = require(\"element-ui/lib/icon\");","module.exports = require(\"core-js/modules/es.object.assign\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SideBar.vue?vue&type=style&index=0&id=11bc3f45&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SideBar.vue?vue&type=style&index=0&id=11bc3f45&scoped=true&lang=scss&\"","module.exports = require(\"core-js/modules/es.function.name\");","module.exports = require(\"core-js/modules/web.dom-collections.for-each\");","module.exports = require(\"core-js/modules/es.string.search\");","module.exports = require(\"core-js/modules/es.string.replace\");","// extracted by mini-css-extract-plugin","module.exports = require(\"element-ui/lib/option\");","// extracted by mini-css-extract-plugin","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BadgesGroup.vue?vue&type=style&index=0&id=3f3b3b02&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BadgesGroup.vue?vue&type=style&index=0&id=3f3b3b02&scoped=true&lang=scss&\"","// extracted by mini-css-extract-plugin","// extracted by mini-css-extract-plugin","module.exports = require(\"element-ui/lib/theme-chalk/tag.css\");","module.exports = require(\"core-js/modules/es.array.last-index-of\");","module.exports = require(\"current-script-polyfill\");","module.exports = require(\"core-js/modules/es.array.from\");","module.exports = require(\"element-ui/lib/input\");","// extracted by mini-css-extract-plugin","module.exports = require(\"core-js/modules/es.object.entries\");","module.exports = require(\"core-js/modules/es.array.unscopables.flat\");","module.exports = require(\"core-js/modules/es.array.map\");","module.exports = require(\"core-js/modules/es.promise.finally\");","// This file is imported into lib/wc client bundles.\n\nif (typeof window !== 'undefined') {\n if (process.env.NEED_CURRENTSCRIPT_POLYFILL) {\n require('current-script-polyfill')\n }\n\n var i\n if ((i = window.document.currentScript) && (i = i.src.match(/(.+\\/)[^/]+\\.js(\\?.*)?$/))) {\n __webpack_public_path__ = i[1] // eslint-disable-line\n }\n}\n\n// Indicate to webpack that this file can be concatenated\nexport default null\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{ref:\"container\"},[(!_vm.drawerOpen)?_c('div',{staticClass:\"open-tab\",on:{\"click\":_vm.toggleDrawer}},[_c('i',{staticClass:\"el-icon-arrow-left\"})]):_vm._e(),_c('el-drawer',{staticClass:\"side-bar\",attrs:{\"custom-class\":\"my-drawer\",\"visible\":_vm.drawerOpen,\"appendToBody\":false,\"modal-append-to-body\":false,\"size\":\"550\",\"with-header\":false,\"wrapperClosable\":false,\"modal\":false},on:{\"update:visible\":function($event){_vm.drawerOpen=$event}}},[_c('div',{staticClass:\"box-card\"},[(_vm.drawerOpen)?_c('div',{staticClass:\"close-tab\",on:{\"click\":_vm.close}},[_c('i',{staticClass:\"el-icon-arrow-right\"})]):_vm._e(),_c('div',{staticClass:\"sidebar-container\"},[(_vm.tabs.length > 1)?_c('tabs',{attrs:{\"tabTitles\":_vm.tabs,\"activeId\":_vm.activeId},on:{\"titleClicked\":_vm.tabClicked}}):_vm._e(),_vm._l((_vm.tabs),function(tab){return [_c('sidebar-content',{directives:[{name:\"show\",rawName:\"v-show\",value:(tab.id===_vm.activeId),expression:\"tab.id===activeId\"}],key:tab.id,ref:tab.id,refInFor:true,staticClass:\"sidebar-content-container\",attrs:{\"contextCardEntry\":tab.contextCard,\"envVars\":_vm.envVars},on:{\"search-changed\":function($event){return _vm.searchChanged(tab.id, $event)}}})]})],2)])])],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nexport default function _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('el-card',{staticClass:\"content-card\",attrs:{\"body-style\":_vm.bodyStyle}},[_c('div',{staticClass:\"header\",attrs:{\"slot\":\"header\"},slot:\"header\"},[_c('el-input',{staticClass:\"search-input\",attrs:{\"placeholder\":\"Search\",\"clearable\":\"\"},on:{\"clear\":_vm.clearSearchClicked},nativeOn:{\"keyup\":function($event){return _vm.searchEvent($event)}},model:{value:(_vm.searchInput),callback:function ($$v) {_vm.searchInput=$$v},expression:\"searchInput\"}}),_c('el-button',{staticClass:\"button\",on:{\"click\":_vm.searchEvent}},[_vm._v(\"Search\")])],1),_c('SearchFilters',{ref:\"filtersRef\",staticClass:\"filters\",attrs:{\"entry\":_vm.filterEntry,\"envVars\":_vm.envVars},on:{\"filterResults\":_vm.filterUpdate,\"numberPerPage\":_vm.numberPerPageUpdate,\"loading\":_vm.filtersLoading,\"cascaderReady\":_vm.cascaderReady}}),_c('search-history',{ref:\"searchHistory\",on:{\"search\":_vm.searchHistorySearch}}),_c('div',{directives:[{name:\"loading\",rawName:\"v-loading\",value:(_vm.loadingCards),expression:\"loadingCards\"}],ref:\"content\",staticClass:\"content scrollbar\"},[(_vm.results.length === 0 && !_vm.loadingCards)?_c('div',{staticClass:\"error-feedback\"},[_vm._v(\" No results found - Please change your search / filter criteria. \")]):_vm._e(),_vm._l((_vm.results),function(result){return _c('div',{key:result.doi,staticClass:\"step-item\"},[_c('DatasetCard',{attrs:{\"entry\":result,\"envVars\":_vm.envVars}})],1)}),_c('el-pagination',{staticClass:\"pagination\",attrs:{\"current-page\":_vm.page,\"hide-on-single-page\":\"\",\"large\":\"\",\"layout\":\"prev, pager, next\",\"page-size\":_vm.numberPerPage,\"total\":_vm.numberOfHits},on:{\"update:currentPage\":function($event){_vm.page=$event},\"update:current-page\":function($event){_vm.page=$event},\"current-change\":_vm.pageChange}})],2)],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","export default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) {\n for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n }\n}","export default function _iterableToArray(iter) {\n if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter);\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance\");\n}","import arrayWithoutHoles from \"./arrayWithoutHoles\";\nimport iterableToArray from \"./iterableToArray\";\nimport nonIterableSpread from \"./nonIterableSpread\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || nonIterableSpread();\n}","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"filters\"},[_c('map-svg-sprite-color'),_c('transition',{attrs:{\"name\":\"el-zoom-in-top\"}},[_c('span',{directives:[{name:\"show\",rawName:\"v-show\",value:(_vm.showFilters),expression:\"showFilters\"}],staticClass:\"search-filters transition-box\"},[_c('custom-cascader',{ref:\"cascader\",staticClass:\"cascader\",attrs:{\"placeholder\":\"\",\"collapse-tags\":true,\"options\":_vm.options,\"props\":_vm.props,\"show-all-levels\":false,\"append-to-body\":false},on:{\"change\":function($event){return _vm.cascadeEvent($event)},\"expand-change\":_vm.cascadeExpandChange,\"tags-changed\":_vm.tagsChangedCallback},model:{value:(_vm.cascadeSelected),callback:function ($$v) {_vm.cascadeSelected=$$v},expression:\"cascadeSelected\"}}),(_vm.showFiltersText)?_c('div',{staticClass:\"filter-default-value\"},[_vm._v(\" Filters \")]):_vm._e(),_c('el-popover',{attrs:{\"title\":\"How do filters work?\",\"width\":\"250\",\"trigger\":\"hover\",\"append-to-body\":false,\"popper-class\":\"popover\"}},[_c('map-svg-icon',{staticClass:\"help\",attrs:{\"slot\":\"reference\",\"icon\":\"help\"},slot:\"reference\"}),_c('div',[_c('strong',[_vm._v(\"Within categories:\")]),_vm._v(\" OR \"),_c('br'),_vm._v(\" example: 'heart' OR 'colon' \"),_c('br'),_c('br'),_c('strong',[_vm._v(\"Between categories:\")]),_vm._v(\" AND \"),_c('br'),_vm._v(\" example: 'rat' AND 'lung' \")])],1)],1)]),_c('el-select',{staticClass:\"number-shown-select\",attrs:{\"placeholder\":\"10\"},on:{\"change\":function($event){return _vm.numberShownChanged($event)}},model:{value:(_vm.numberShown),callback:function ($$v) {_vm.numberShown=$$v},expression:\"numberShown\"}},_vm._l((_vm.numberDatasetsShown),function(item){return _c('el-option',{key:item,attrs:{\"label\":item,\"value\":item}})}),1),_c('span',{staticClass:\"dataset-results-feedback\"},[_vm._v(_vm._s(this.numberOfResultsText))])],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n}","import arrayWithHoles from \"./arrayWithHoles\";\nimport iterableToArray from \"./iterableToArray\";\nimport nonIterableRest from \"./nonIterableRest\";\nexport default function _toArray(arr) {\n return arrayWithHoles(arr) || iterableToArray(arr) || nonIterableRest();\n}","<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport { Cascader } from \"element-ui\";\r\n\r\nexport default {\r\n name: 'CustomCascader',\r\n extends: Cascader,\r\n methods:{\r\n //Modify this internal function to disable Show all tags\r\n computePresentTags() {\r\n const { isDisabled, leafOnly, showAllLevels, separator, collapseTags } = this;\r\n const checkedNodes = this.getCheckedNodes(leafOnly);\r\n const tags = [];\r\n const genTag = node => ({\r\n node,\r\n key: node.uid,\r\n text: node.getText(showAllLevels, separator),\r\n hitState: false,\r\n closable: !isDisabled && !node.isDisabled\r\n });\r\n let customNodes = checkedNodes.filter(node =>\r\n {\r\n return !(node.getText(showAllLevels, separator).includes(\"Show all\"));\r\n }\r\n );\r\n if (customNodes.length) {\r\n const [first, ...rest] = customNodes;\r\n const restCount = rest.length;\r\n tags.push(genTag(first));\r\n if (restCount) {\r\n if (collapseTags) {\r\n tags.push({\r\n key: -1,\r\n text: `+ ${restCount}`,\r\n closable: false\r\n });\r\n } else {\r\n rest.forEach(node => tags.push(genTag(node)));\r\n }\r\n }\r\n }\r\n this.checkedNodes = checkedNodes;\r\n this.presentTags = tags;\r\n this.$emit(\"tags-changed\", this.presentTags);\r\n }\r\n }\r\n}\r\n\r\n</script>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Cascader.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Cascader.vue?vue&type=script&lang=js&\"","/* globals __VUE_SSR_CONTEXT__ */\n\n// IMPORTANT: Do NOT use ES2015 features in this file (except for modules).\n// This module is a runtime utility for cleaner component module output and will\n// be included in the final webpack user bundle.\n\nexport default function normalizeComponent (\n scriptExports,\n render,\n staticRenderFns,\n functionalTemplate,\n injectStyles,\n scopeId,\n moduleIdentifier, /* server only */\n shadowMode /* vue-cli only */\n) {\n // Vue.extend constructor export interop\n var options = typeof scriptExports === 'function'\n ? scriptExports.options\n : scriptExports\n\n // render functions\n if (render) {\n options.render = render\n options.staticRenderFns = staticRenderFns\n options._compiled = true\n }\n\n // functional template\n if (functionalTemplate) {\n options.functional = true\n }\n\n // scopedId\n if (scopeId) {\n options._scopeId = 'data-v-' + scopeId\n }\n\n var hook\n if (moduleIdentifier) { // server build\n hook = function (context) {\n // 2.3 injection\n context =\n context || // cached call\n (this.$vnode && this.$vnode.ssrContext) || // stateful\n (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional\n // 2.2 with runInNewContext: true\n if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {\n context = __VUE_SSR_CONTEXT__\n }\n // inject component styles\n if (injectStyles) {\n injectStyles.call(this, context)\n }\n // register component module identifier for async chunk inferrence\n if (context && context._registeredComponents) {\n context._registeredComponents.add(moduleIdentifier)\n }\n }\n // used by ssr in case component is cached and beforeCreate\n // never gets called\n options._ssrRegister = hook\n } else if (injectStyles) {\n hook = shadowMode\n ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }\n : injectStyles\n }\n\n if (hook) {\n if (options.functional) {\n // for template-only hot-reload because in that case the render fn doesn't\n // go through the normalizer\n options._injectStyles = hook\n // register for functioal component in vue file\n var originalRender = options.render\n options.render = function renderWithStyleInjection (h, context) {\n hook.call(context)\n return originalRender(h, context)\n }\n } else {\n // inject component registration as beforeCreate hook\n var existing = options.beforeCreate\n options.beforeCreate = existing\n ? [].concat(existing, hook)\n : [hook]\n }\n }\n\n return {\n exports: scriptExports,\n options: options\n }\n}\n","var render, staticRenderFns\nimport script from \"./Cascader.vue?vue&type=script&lang=js&\"\nexport * from \"./Cascader.vue?vue&type=script&lang=js&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports","export default {\r\n 'homo sapiens': 'Human',\r\n 'rattus norvegicus': 'Rat',\r\n 'mus musculus': 'Mouse',\r\n 'sus scrofa domesticus': 'Pig',\r\n 'sus scrofa': 'Boar',\r\n 'felis catus': 'Cat'\r\n}\r\n","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}","/* eslint-disable no-alert, no-console */\r\nimport algoliasearch from 'algoliasearch'\r\n\r\n// export `createAlgoliaClient` to use it in page components\r\nexport class AlgoliaClient {\r\n constructor(algoliaId, algoliaKey, PENNSIEVE_API_LOCATION = 'https://api.pennsieve.io') {\r\n this.client = algoliasearch(\r\n algoliaId,\r\n algoliaKey\r\n )\r\n this.PENNSIEVE_API_LOCATION = PENNSIEVE_API_LOCATION\r\n this.anatomyFacetLabels = []\r\n }\r\n initIndex(ALGOLIA_INDEX) {\r\n this.index = this.client.initIndex(ALGOLIA_INDEX);\r\n }\r\n\r\n getAlgoliaFacets(propPathMapping) {\r\n const map = new Map(Object.entries(propPathMapping));\r\n const facetPropPaths = Array.from(map.keys());\r\n let facetData = []\r\n let facetId = 0\r\n return this.index\r\n .search('', {\r\n sortFacetValuesBy: 'alpha',\r\n facets: facetPropPaths\r\n })\r\n .then(response => {\r\n facetPropPaths.map((facetPropPath) => {\r\n var children = []\r\n const responseFacets = response.facets\r\n if (responseFacets === undefined) { return }\r\n const responseFacetChildren =\r\n responseFacets[facetPropPath] == undefined\r\n ? {}\r\n : responseFacets[facetPropPath]\r\n Object.keys(responseFacetChildren).map(facet => {\r\n children.push({\r\n label: facet,\r\n id: facetId++,\r\n facetPropPath: facetPropPath\r\n })\r\n })\r\n if (children.length > 0) {\r\n facetData.push({\r\n label: map.get(facetPropPath),\r\n id: facetId++,\r\n children: children,\r\n key: facetPropPath\r\n })\r\n }\r\n })\r\n return facetData\r\n })\r\n }\r\n\r\n // Returns all DOIs of all versions for a given discover dataset\r\n _discoverAllDois(discoverId, PENNSIEVE_API_LOCATION = 'https://api.pennsieve.io') {\r\n return new Promise(resolve => {\r\n fetch(`${PENNSIEVE_API_LOCATION}/discover/datasets/${discoverId}/versions`).then(r => r.json()).then(dataset => {\r\n resolve(dataset.map(version => version.doi))\r\n })\r\n })\r\n }\r\n\r\n // Get all dois given a list of discoverIds\r\n _expandDois(discoverIds, PENNSIEVE_API_LOCATION = 'https://api.pennsieve.io') {\r\n return new Promise(resolve => {\r\n let promiseList = discoverIds.map(discoverId => this._discoverAllDois(discoverId, PENNSIEVE_API_LOCATION))\r\n Promise.all(promiseList).then((values) => {\r\n resolve(values.flat())\r\n });\r\n })\r\n }\r\n\r\n _processResultsForCards(results) {\r\n let newResults = []\r\n let newResult = {}\r\n for (let res of results) {\r\n newResult = { ...res }\r\n newResult = {\r\n doi: res.item.curie.split(':')[1],\r\n name: res.item.name,\r\n description: res.item.description,\r\n updated: res.pennsieve ? res.pennsieve.updatedAt : undefined,\r\n publishDate: res.pennsieve ? res.pennsieve.publishDate : undefined,\r\n datasetId: res.objectID,\r\n detailsReady: false\r\n }\r\n newResults.push(newResult)\r\n }\r\n return newResults\r\n }\r\n\r\n _processAnatomy(hits) {\r\n let foundKeyWords = []\r\n let foundLabels = []\r\n let uniqueLabels = []\r\n let uniqueKeywords = []\r\n hits.forEach(hit => {\r\n if (hit.item && hit.item.keywords) {\r\n hit.item.keywords.forEach(keywordObj => {\r\n let keyword = keywordObj.keyword.toUpperCase()\r\n if (keyword.includes('UBERON') || keyword.includes('ILX')) {\r\n foundKeyWords.push(this._processUberonURL(keyword))\r\n }\r\n })\r\n }\r\n if (hit.anatomy && hit.anatomy.organ ) {\r\n hit.anatomy.organ.forEach(anatomy => {\r\n if (anatomy.curie) {\r\n foundKeyWords.push(anatomy.curie)\r\n foundLabels.push(anatomy.name)\r\n }\r\n })\r\n }\r\n })\r\n uniqueKeywords = [...new Set(foundKeyWords) ]\r\n uniqueLabels = [...new Set(foundLabels) ]\r\n this.anatomyFacetLabels = uniqueLabels\r\n return uniqueKeywords\r\n }\r\n\r\n _processUberonURL(url) {\r\n let ub = url.split('/').pop()\r\n return ub.replace('_', ':')\r\n }\r\n\r\n /**\r\n * Get Search results\r\n * This is using fetch from the Algolia API\r\n */\r\n search(filter, query = '', hitsperPage = 10, page = 1) {\r\n return new Promise(resolve => {\r\n this.index\r\n .search(query, {\r\n facets: ['*'],\r\n hitsPerPage: hitsperPage,\r\n page: page - 1,\r\n filters: filter,\r\n attributesToHighlight: [],\r\n attributesToRetrieve: [\r\n 'pennsieve.publishDate',\r\n 'pennsieve.updatedAt',\r\n 'item.curie',\r\n 'item.name',\r\n 'item.description',\r\n 'objectID',\r\n ],\r\n })\r\n .then(response => {\r\n let searchData = {\r\n items: this._processResultsForCards(response.hits),\r\n total: response.nbHits,\r\n discoverIds: response.hits.map(r => r.pennsieve ? r.pennsieve.identifier : r.objectID),\r\n dois: response.hits.map(r => r.item.curie.split(':')[1])\r\n }\r\n resolve(searchData)\r\n })\r\n })\r\n }\r\n\r\n /**\r\n * Get key words\r\n * This is used to return all keywords for a given search. Note that you often want the hits per page to be maxed out\r\n */\r\n anatomyInSearch(filter, query = '', hitsperPage = 999999, page = 1) {\r\n return new Promise(resolve => {\r\n this.index\r\n .search(query, {\r\n facets: ['*'],\r\n hitsPerPage: hitsperPage,\r\n page: page - 1,\r\n filters: filter,\r\n attributesToHighlight: [],\r\n attributesToRetrieve: [\r\n 'item.keywords.keyword',\r\n 'anatomy.organ.name',\r\n 'anatomy.organ.curie'\r\n ],\r\n })\r\n .then(response => {\r\n let anatomyAsUberons = this._processAnatomy(response.hits)\r\n resolve(anatomyAsUberons)\r\n })\r\n })\r\n }\r\n}\r\n","/* eslint-disable no-alert, no-console */\r\n\r\n// Mapping between display categories and their Algolia index property path\r\n// Used for populating the Dataset Search Results facet menu dynamically\r\nexport const facetPropPathMapping = {\r\n 'anatomy.organ.name' : 'Anatomical Structure',\r\n 'organisms.primary.species.name' : 'Species',\r\n 'item.modalities.keyword' : 'Experimental Approach',\r\n 'attributes.subject.sex.value' : 'Sex',\r\n 'attributes.subject.ageCategory.value' : 'Age Categories',\r\n 'item.types.name' : 'Data type',\r\n}\r\n\r\n// Same as above, but these show on the sidebar filters\r\nexport const shownFilters = {\r\n 'anatomy.organ.name' : 'Anatomical Structure',\r\n 'organisms.primary.species.name' : 'Species',\r\n 'attributes.subject.sex.value' : 'Sex',\r\n 'attributes.subject.ageCategory.value' : 'Age Categories',\r\n 'item.types.name' : 'Data type',\r\n}\r\n\r\n/* Returns filter for searching algolia. All facets of the same category are joined with OR,\r\n * and each of those results is then joined with an AND.\r\n * i.e. (color:blue OR color:red) AND (shape:circle OR shape:red) */\r\nexport function getFilters(selectedFacetArray=undefined) {\r\n // return all datasets if no filter\r\n if (selectedFacetArray === undefined) {\r\n return 'NOT item.published.status:embargo'\r\n }\r\n\r\n // Switch the 'term' attribute to 'label' if 'label' does not exist \r\n selectedFacetArray.forEach(f=>f.label=f.facet)\r\n \r\n\r\n let facets = removeShowAllFacets(selectedFacetArray)\r\n\r\n let filters = \"NOT item.published.status:embargo\";\r\n filters = `(${filters}) AND `;\r\n\r\n const facetPropPaths = Object.keys(facetPropPathMapping);\r\n facetPropPaths.map((facetPropPath) => {\r\n const facetsToBool = facets.filter(\r\n (facet) => facet.facetPropPath == facetPropPath\r\n );\r\n let orFilters = \"\";\r\n let andFilters = \"\";\r\n facetsToBool.map((facet) => {\r\n if (facet.AND){\r\n andFilters += `AND \"${facetPropPath}\":\"${facet.label}\"`;\r\n } else {\r\n orFilters += `\"${facetPropPath}\":\"${facet.label}\" OR `;\r\n }\r\n });\r\n if (orFilters == \"\" && andFilters ==\"\") {\r\n return;\r\n }\r\n orFilters = `(${orFilters.substring(0, orFilters.lastIndexOf(\" OR \"))})` // remove last OR\r\n\r\n filters += `${orFilters + andFilters} AND `; // Put them together\r\n // (Note that we add an extra AND in case there are facets at a higher level)\r\n\r\n filters = filters.split('()AND ').join(''); // Handle case where there where no OR facets\r\n });\r\n return filters.substring(0, filters.lastIndexOf(\" AND \"));\r\n}\r\n\r\nfunction removeShowAllFacets(facetArray){\r\n return facetArray.filter( f => f.label !== 'Show all')\r\n}","<template>\r\n <div class=\"filters\">\r\n <map-svg-sprite-color />\r\n <transition name=\"el-zoom-in-top\">\r\n <span v-show=\"showFilters\" class=\"search-filters transition-box\">\r\n <custom-cascader\r\n class=\"cascader\"\r\n ref=\"cascader\"\r\n v-model=\"cascadeSelected\"\r\n placeholder\r\n :collapse-tags=\"true\"\r\n :options=\"options\"\r\n :props=\"props\"\r\n @change=\"cascadeEvent($event)\"\r\n @expand-change=\"cascadeExpandChange\"\r\n :show-all-levels=\"false\"\r\n :append-to-body=\"false\"\r\n @tags-changed=\"tagsChangedCallback\"\r\n ></custom-cascader>\r\n <div v-if=\"showFiltersText\" class=\"filter-default-value\">\r\n Filters\r\n </div>\r\n <el-popover\r\n title=\"How do filters work?\"\r\n width=\"250\"\r\n trigger=\"hover\"\r\n :append-to-body=false\r\n popper-class=\"popover\"\r\n >\r\n <map-svg-icon slot=\"reference\" icon=\"help\" class=\"help\"/>\r\n <div >\r\n <strong>Within categories:</strong> OR \r\n <br/>\r\n example: 'heart' OR 'colon'\r\n <br/>\r\n <br/>\r\n <strong>Between categories:</strong> AND\r\n <br/>\r\n example: 'rat' AND 'lung'\r\n </div>\r\n </el-popover>\r\n \r\n </span>\r\n </transition>\r\n\r\n <el-select\r\n class=\"number-shown-select\"\r\n v-model=\"numberShown\"\r\n placeholder=\"10\"\r\n @change=\"numberShownChanged($event)\"\r\n >\r\n <el-option\r\n v-for=\"item in numberDatasetsShown\"\r\n :key=\"item\"\r\n :label=\"item\"\r\n :value=\"item\"\r\n ></el-option>\r\n </el-select>\r\n <span class=\"dataset-results-feedback\">{{ this.numberOfResultsText }}</span>\r\n </div>\r\n</template>\r\n\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport { Option, Select, Popover } from \"element-ui\";\r\nimport CustomCascader from \"./Cascader\";\r\nimport lang from \"element-ui/lib/locale/lang/en\";\r\nimport locale from \"element-ui/lib/locale\";\r\nimport speciesMap from \"./species-map\";\r\nimport { MapSvgIcon, MapSvgSpriteColor } from \"@abi-software/svg-sprite\";\r\n\r\nimport {AlgoliaClient} from \"../algolia/algolia.js\";\r\nimport {facetPropPathMapping} from \"../algolia/utils.js\";\r\n\r\nlocale.use(lang);\r\nVue.use(Option);\r\nVue.use(Select);\r\nVue.use(Popover)\r\n\r\nconst capitalise = function (txt) {\r\n return txt.charAt(0).toUpperCase() + txt.slice(1);\r\n};\r\n\r\nconst convertReadableLabel = function (original) {\r\n const name = original.toLowerCase();\r\n if (speciesMap[name]) {\r\n return capitalise(speciesMap[name]);\r\n } else {\r\n return capitalise(name);\r\n }\r\n};\r\n\r\nexport default {\r\n name: \"SearchFilters\",\r\n components: {\r\n CustomCascader,\r\n MapSvgIcon,\r\n MapSvgSpriteColor,\r\n },\r\n props: {\r\n /**\r\n * Object containing information for\r\n * the required viewing.\r\n */\r\n entry: Object,\r\n envVars: {\r\n type: Object,\r\n default: ()=>{}\r\n },\r\n },\r\n data: function () {\r\n return {\r\n cascaderIsReady: false,\r\n previousShowAllChecked: {\r\n species: false,\r\n gender: false,\r\n organ: false,\r\n datasets: false,\r\n },\r\n showFilters: true,\r\n showFiltersText: true,\r\n cascadeSelected: [],\r\n cascadeSelectedWithBoolean: [], \r\n numberShown: 10,\r\n filters: [],\r\n facets: [\"Species\", \"Gender\", \"Organ\", \"Datasets\"],\r\n numberDatasetsShown: [\"10\", \"20\", \"50\"],\r\n props: { multiple: true },\r\n options: [\r\n {\r\n value: \"Species\",\r\n label: \"Species\",\r\n children: [{}],\r\n },\r\n ],\r\n };\r\n },\r\n computed: {\r\n numberOfResultsText: function () {\r\n return `${this.entry.numberOfHits} results | Showing`;\r\n },\r\n },\r\n methods: {\r\n createCascaderItemValue: function (term, facet) {\r\n if (facet) return term + \">\" + facet;\r\n else return term;\r\n },\r\n populateCascader: function () {\r\n return new Promise((resolve) => {\r\n // Algolia facet serach\r\n this.algoliaClient.getAlgoliaFacets(facetPropPathMapping)\r\n .then((data) => {\r\n this.facets = data;\r\n this.options = data;\r\n\r\n // create top level of options in cascader\r\n this.options.forEach((facet, i) => {\r\n this.options[i].label = convertReadableLabel(facet.label);\r\n this.options[i].value = this.createCascaderItemValue(\r\n facet.key,\r\n undefined\r\n );\r\n\r\n // put \"Show all\" as first option\r\n this.options[i].children.unshift({\r\n value: this.createCascaderItemValue(\"Show all\"),\r\n label: \"Show all\",\r\n });\r\n\r\n // populate second level of options \r\n this.options[i].children.forEach((facetItem, j) => {\r\n this.options[i].children[j].label = convertReadableLabel(\r\n facetItem.label\r\n );\r\n this.options[i].children[j].value =\r\n this.createCascaderItemValue(facet.label, facetItem.label);\r\n });\r\n });\r\n })\r\n .finally(() => {\r\n resolve();\r\n });\r\n });\r\n },\r\n tagsChangedCallback: function (presentTags) {\r\n if (presentTags.length > 0) {\r\n this.showFiltersText = false;\r\n } else {\r\n this.showFiltersText = true;\r\n }\r\n },\r\n // cascadeEvent: initiate searches based off cascader changes\r\n cascadeEvent: function (event) {\r\n if (event) {\r\n // Check for show all in selected cascade options\r\n event = this.showAllEventModifier(event);\r\n\r\n // Create results for the filter update \r\n let filterKeys = event.filter( selection => selection !== undefined).map( fs => ({\r\n facetPropPath: fs[0], \r\n facet: fs[1].split(\">\")[1],\r\n term: fs[1].split(\">\")[0], \r\n AND: fs[2] // for setting the boolean\r\n }))\r\n\r\n // Move results from arrays to object for use on scicrunch (note that we remove 'duplicate' as that is only needed for filter keys)\r\n let filters = event.filter( selection => selection !== undefined).map( fs => {\r\n let propPath = fs[0].includes('duplicate') ? fs[0].split('duplicate')[0] : fs[0]\r\n return {\r\n facetPropPath: propPath, \r\n facet: fs[1].split(\">\")[1],\r\n term: fs[1].split(\">\")[0], \r\n AND: fs[2] // for setting the boolean\r\n }\r\n })\r\n\r\n\r\n this.$emit('loading', true) // let sidebarcontent wait for the requests\r\n\r\n this.$emit(\"filterResults\", filters); // emit filters for apps above sidebar\r\n this.setCascader(filterKeys); //update our cascader v-model if we modified the event\r\n this.makeCascadeLabelsClickable();\r\n }\r\n },\r\n // showAllEventModifier: Modifies a cascade event to unclick all selections in category if \"show all\" is clicked. Also unchecks \"Show all\" if any secection is clicked\r\n // *NOTE* Does NOT remove 'Show all' selections from showing in 'cascadeSelected'\r\n showAllEventModifier: function (event) {\r\n // check if show all is in the cascader checked option list\r\n let hasShowAll = event\r\n .map((ev) => (ev ? ev[1].toLowerCase().includes(\"show all\") : false))\r\n .includes(true);\r\n // remove all selected options below the show all if checked\r\n if (hasShowAll) {\r\n let modifiedEvent = [];\r\n let facetMaps = {};\r\n //catagorised different facet items\r\n for (const i in event) {\r\n if (facetMaps[event[i][0]] === undefined) facetMaps[event[i][0]] = [];\r\n facetMaps[event[i][0]].push(event[i]);\r\n }\r\n // go through each facets\r\n for (const facet in facetMaps) {\r\n let showAll = undefined;\r\n // Find the show all item if any\r\n for (let i = facetMaps[facet].length - 1; i >= 0; i--) {\r\n if (facetMaps[facet][i][1].toLowerCase().includes(\"show all\")) {\r\n //seperate the showAll item and the rest\r\n showAll = facetMaps[facet].splice(i, 1)[0];\r\n break;\r\n }\r\n }\r\n if (showAll) {\r\n if (this.previousShowAllChecked[facet]) {\r\n //Unset the show all if it was present previously\r\n //and there are other items\r\n if (facetMaps[facet].length > 0)\r\n modifiedEvent.push(...facetMaps[facet]);\r\n else modifiedEvent.push(showAll);\r\n } else {\r\n //showAll is turned on\r\n modifiedEvent.push(showAll);\r\n }\r\n } else {\r\n modifiedEvent.push(...facetMaps[facet]);\r\n }\r\n }\r\n //Make sure the expanded item are sorted first.\r\n return modifiedEvent.sort((a, b) => {\r\n if (this.__expandItem__) {\r\n if (a[0] == this.__expandItem__) {\r\n if (b[0] == this.__expandItem__) {\r\n return 0;\r\n } else {\r\n return -1;\r\n }\r\n } else if (b[0] == this.__expandItem__) {\r\n if (a[0] == this.__expandItem__) {\r\n return 0;\r\n } else {\r\n return 1;\r\n }\r\n } else {\r\n return 0;\r\n }\r\n } else return 0;\r\n });\r\n }\r\n return event;\r\n },\r\n cascadeExpandChange: function (event) {\r\n //work around as the expand item may change on modifying the cascade props\r\n this.__expandItem__ = event;\r\n this.makeCascadeLabelsClickable();\r\n },\r\n numberShownChanged: function (event) {\r\n this.$emit(\"numberPerPage\", parseInt(event));\r\n },\r\n updatePreviousShowAllChecked: function (options) {\r\n //Reset the states\r\n for (const facet in this.previousShowAllChecked) {\r\n this.previousShowAllChecked[facet] = false;\r\n }\r\n options.forEach((element) => {\r\n if (element[1].toLowerCase().includes(\"show all\"))\r\n this.previousShowAllChecked[element[0]] = true;\r\n });\r\n },\r\n // setCascader: Clears previous selections and takes in an array of facets to select: filterFacets\r\n // facets are in the form:\r\n // {\r\n // facetPropPath: 'anatomy.organ.name',\r\n // term: 'Sex',\r\n // facet: 'Male'\r\n // AND: true // Optional value for setting the boolean within a facet\r\n // }\r\n setCascader: function (filterFacets) {\r\n //Do not set the value unless it is ready\r\n if (this.cascaderIsReady && filterFacets && filterFacets.length != 0) {\r\n this.cascadeSelected = filterFacets.map(e => {\r\n return [\r\n e.facetPropPath,\r\n this.createCascaderItemValue(capitalise(e.term), e.facet),\r\n ]\r\n });\r\n\r\n // Unforttunately the cascader is very particular about it's v-model\r\n // to get around this we create a clone of it and use this clone for adding our boolean information\r\n this.cascadeSelectedWithBoolean= filterFacets.map(e => {\r\n return [\r\n e.facetPropPath,\r\n this.createCascaderItemValue(capitalise(e.term), e.facet),\r\n e.AND\r\n ]\r\n });\r\n this.updatePreviousShowAllChecked(this.cascadeSelected);\r\n }\r\n },\r\n addFilter: function (filter) {\r\n //Do not set the value unless it is ready\r\n if (this.cascaderIsReady && filter) {\r\n if (this.validateFilter(filter)) {\r\n this.cascadeSelected.filter(f=>f.term != filter.term)\r\n this.cascadeSelected.push([filter.facetPropPath, this.createCascaderItemValue(filter.term, filter.facet), filter.AND])\r\n this.cascadeSelectedWithBoolean.push([filter.facetPropPath, this.createCascaderItemValue(filter.term, filter.facet), filter.AND])\r\n // The 'AND' her is to set the boolean value when we search on the filters. It can be undefined without breaking anything\r\n return true;\r\n }\r\n }\r\n },\r\n initiateSearch: function() {\r\n this.cascadeEvent(this.cascadeSelectedWithBoolean)\r\n },\r\n // checkShowAllBoxes: Checks each 'Show all' cascade option by using the setCascader function\r\n checkShowAllBoxes: function(){\r\n this.setCascader(\r\n this.options.map(option => {\r\n return {\r\n facetPropPath: option.value,\r\n term: option.label,\r\n facet: 'Show all'\r\n }\r\n })\r\n )\r\n },\r\n makeCascadeLabelsClickable: function () {\r\n // Next tick allows the cascader menu to change\r\n this.$nextTick(() => {\r\n this.$refs.cascader.$el\r\n .querySelectorAll(\".el-cascader-node__label\")\r\n .forEach((el) => {\r\n // step through each cascade label\r\n el.onclick = function () {\r\n const checkbox = this.previousElementSibling;\r\n if (checkbox) {\r\n if (!checkbox.parentElement.attributes[\"aria-owns\"]) {\r\n // check if we are at the lowest level of cascader\r\n this.previousElementSibling.click(); // Click the checkbox\r\n }\r\n }\r\n };\r\n });\r\n });\r\n },\r\n /**\r\n * Validate ther filter term to make sure the term is correct\r\n */\r\n validateFilter: function(filter) {\r\n if (filter && filter.facet && filter.term) {\r\n const item = this.createCascaderItemValue(filter.term, filter.facet);\r\n const facet = this.options.find(element => element.value === filter.facetPropPath);\r\n if (facet) {\r\n const filter = facet.children.find(element => element.value === item);\r\n if (filter)\r\n return true;\r\n }\r\n }\r\n return false;\r\n },\r\n /**\r\n * Return a list of valid filers given a list of filters, \r\n */\r\n getValidatedFilters: function (filters) {\r\n if (filters) {\r\n if (this.cascaderIsReady) {\r\n const result = [];\r\n filters.forEach(filter => {\r\n if (this.validateFilter(filter)) {\r\n result.push(filter);\r\n }\r\n });\r\n return result;\r\n } else return filters;\r\n }\r\n return [];\r\n },\r\n },\r\n mounted: function () {\r\n this.algoliaClient = new AlgoliaClient(this.envVars.ALGOLIA_ID, this.envVars.ALGOLIA_KEY, this.envVars.PENNSIEVE_API_LOCATION);\r\n this.algoliaClient.initIndex(this.envVars.ALGOLIA_INDEX);\r\n this.populateCascader().then(() => {\r\n this.cascaderIsReady = true;\r\n this.checkShowAllBoxes();\r\n this.setCascader(this.entry.filterFacets);\r\n this.makeCascadeLabelsClickable();\r\n this.$emit(\"cascaderReady\");\r\n });\r\n },\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/option\";\r\n@import \"~element-ui/packages/theme-chalk/src/popover\";\r\n@import \"~element-ui/packages/theme-chalk/src/select\";\r\n\r\n.filter-default-value {\r\n pointer-events: none;\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n padding-top: 10px;\r\n padding-left: 16px;\r\n}\r\n\r\n.help {\r\n width: 24px !important;\r\n height: 24px;\r\n transform: scale(1.1);\r\n cursor: pointer;\r\n}\r\n\r\n.popover {\r\n color: rgb(48, 49, 51);\r\n font-family: Asap;\r\n margin: 12px;\r\n}\r\n\r\n.filter-icon-inside {\r\n width: 12px !important;\r\n height: 12px !important;\r\n color: #292b66;\r\n transform: scale(2) !important;\r\n margin-bottom: 0px !important;\r\n}\r\n\r\n.cascader {\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-weight: 500;\r\n font-stretch: normal;\r\n font-style: normal;\r\n line-height: normal;\r\n letter-spacing: normal;\r\n color: #292b66;\r\n text-align: center;\r\n padding-bottom: 6px;\r\n}\r\n\r\n.cascader ::v-deep .el-cascder-panel {\r\n max-height: 500px;\r\n}\r\n\r\n.cascader::v-deep .el-scrollbar__wrap {\r\n overflow-x: hidden;\r\n margin-bottom: 2px !important;\r\n}\r\n\r\n.cascader ::v-deep li[aria-owns*=\"cascader\"] > .el-checkbox {\r\n display: none;\r\n}\r\n\r\n.dataset-results-feedback {\r\n float: right;\r\n text-align: right;\r\n color: rgb(48, 49, 51);\r\n font-family: Asap;\r\n font-size: 18px;\r\n font-weight: 500;\r\n padding-top: 8px;\r\n}\r\n\r\n.search-filters {\r\n position: relative;\r\n float: left;\r\n padding-right: 15px;\r\n}\r\n\r\n.number-shown-select {\r\n float: right;\r\n}\r\n\r\n.number-shown-select ::v-deep .el-input__inner {\r\n width: 68px;\r\n height: 40px;\r\n color: rgb(48, 49, 51);\r\n}\r\n\r\n.search-filters ::v-deep .el-cascader-node.is-active {\r\n color: $app-primary-color;\r\n}\r\n\r\n.search-filters ::v-deep .el-cascader-node.in-active-path {\r\n color: $app-primary-color;\r\n}\r\n\r\n.search-filters ::v-deep .el-checkbox__input.is-checked > .el-checkbox__inner {\r\n background-color: $app-primary-color;\r\n border-color: $app-primary-color;\r\n}\r\n\r\n.cascader ::v-deep .el-cascader-menu:nth-child(2) .el-cascader-node:first-child {\r\n border-bottom: 1px solid #e4e7ed;\r\n}\r\n\r\n.cascader ::v-deep .el-cascader-node__label {\r\n text-align: left;\r\n}\r\n\r\n.filters ::v-deep .el-popover {\r\n background: #f3ecf6 !important;\r\n border: 1px solid $app-primary-color;\r\n border-radius: 4px;\r\n color: #303133 !important;\r\n font-size: 12px;\r\n line-height: 18px;\r\n}\r\n\r\n.filters ::v-deep .el-popover[x-placement^=\"top\"] .popper__arrow {\r\n border-top-color: $app-primary-color;\r\n border-bottom-width: 0;\r\n}\r\n.filters ::v-deep .el-popover[x-placement^=\"top\"] .popper__arrow::after {\r\n border-top-color: #f3ecf6;\r\n border-bottom-width: 0;\r\n}\r\n\r\n.filters ::v-deep .el-popover[x-placement^=\"bottom\"] .popper__arrow {\r\n border-top-width: 0;\r\n border-bottom-color: $app-primary-color;\r\n}\r\n.filters ::v-deep .el-popover[x-placement^=\"bottom\"] .popper__arrow::after {\r\n border-top-width: 0;\r\n border-bottom-color: #f3ecf6;\r\n}\r\n\r\n.filters ::v-deep .el-popover[x-placement^=\"right\"] .popper__arrow {\r\n border-right-color: $app-primary-color;\r\n border-left-width: 0;\r\n}\r\n.filters ::v-deep .el-popover[x-placement^=\"right\"] .popper__arrow::after {\r\n border-right-color: #f3ecf6;\r\n border-left-width: 0;\r\n}\r\n\r\n.filters ::v-deep .el-popover[x-placement^=\"left\"] .popper__arrow {\r\n border-right-width: 0;\r\n border-left-color: $app-primary-color;\r\n}\r\n.filters ::v-deep .el-popover[x-placement^=\"left\"] .popper__arrow::after {\r\n border-right-width: 0;\r\n border-left-color: #f3ecf6;\r\n}\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchFilters.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchFilters.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SearchFilters.vue?vue&type=template&id=228b9f2c&scoped=true&\"\nimport script from \"./SearchFilters.vue?vue&type=script&lang=js&\"\nexport * from \"./SearchFilters.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SearchFilters.vue?vue&type=style&index=0&id=228b9f2c&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"228b9f2c\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"container\"},[_vm._l((_vm.reversedSearchHistory),function(item,i){return [(i < 3)?_c('el-tag',{key:i,staticClass:\"search-tag\",on:{\"click\":function($event){return _vm.search(item)}}},[_vm._v(_vm._s(item.search)+\" \")]):_vm._e()]}),(_vm.reversedSearchHistory.length > 0)?_c('el-select',{staticClass:\"m-2 search-select\",attrs:{\"value\":_vm.selectValue,\"placeholder\":\"Full search History\",\"size\":\"small\",\"popper-class\":\"sidebar-search-select-popper\"},on:{\"change\":_vm.selectChange}},_vm._l((_vm.cascaderOptions),function(item,i){return _c('el-option',{key:i,attrs:{\"label\":item.label,\"value\":item.value}})}),1):_vm._e()],2)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","import Vue from 'vue';\r\nconst EventBus = new Vue();\r\nexport default EventBus;\r\n","<template>\r\n <div class=\"container\">\r\n <!-- <span v-if=\"reversedSearchHistory.length > 0\" class=\"title\"> Search History </span> -->\r\n <template v-for=\"(item, i) in reversedSearchHistory\">\r\n <el-tag class=\"search-tag\" v-if=\"i < 3\" v-bind:key=\"i\" @click=\"search(item)\">{{ item.search }} </el-tag>\r\n </template>\r\n <el-select \r\n v-if=\"reversedSearchHistory.length > 0\" \r\n :value=\"selectValue\" \r\n class=\"m-2 search-select\" \r\n placeholder=\"Full search History\" \r\n size=\"small\"\r\n popper-class=\"sidebar-search-select-popper\"\r\n @change=\"selectChange\"\r\n >\r\n <el-option\r\n v-for=\"(item, i) in cascaderOptions\"\r\n :key=\"i\"\r\n :label=\"item.label\"\r\n :value=\"item.value\"\r\n />\r\n </el-select>\r\n </div>\r\n\r\n</template>\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport {\r\n Tag,\r\n Select,\r\n} from \"element-ui\";\r\n\r\nVue.use(Tag);\r\nVue.use(Select);\r\nimport EventBus from './EventBus';\r\n\r\n// remove duplicates by stringifying the objects\r\nconst removeDuplicates = function(arrayOfAnything){\r\n return [...new Set(arrayOfAnything.map(e => JSON.stringify(e)))].map(e => JSON.parse(e)) \r\n}\r\n\r\nexport default {\r\n name: 'SearchHistory',\r\n data() {\r\n return {\r\n searchHistory: [],\r\n selectValue: 'Full search history'\r\n }\r\n\r\n },\r\n computed: {\r\n reversedSearchHistory: function(){\r\n return removeDuplicates(this.searchHistory.slice().reverse().filter(item => item.search !== ''))\r\n },\r\n cascaderOptions: function(){\r\n return this.reversedSearchHistory.map(item => {\r\n return {\r\n value: item.search,\r\n label: item.search\r\n }\r\n })\r\n }\r\n },\r\n methods: {\r\n getSearchHistory() {\r\n if (localStorage.getItem('sparc.science-sidebar-search-history')) {\r\n this.searchHistory = JSON.parse(localStorage.getItem('sparc.science-sidebar-search-history'));\r\n } else {\r\n this.searchHistory = [];\r\n }\r\n },\r\n clearSearchHistory() {\r\n localStorage.removeItem('sparc.science-sidebar-search-history');\r\n this.searchHistory = [];\r\n },\r\n addSearchToHistory(filters, search) {\r\n filters = [] // disable filters for now\r\n let searchHistory = JSON.parse(localStorage.getItem('sparc.science-sidebar-search-history'));\r\n if (searchHistory) {\r\n searchHistory.push({filters: filters, search: search});\r\n this.searchHistory = removeDuplicates(searchHistory)\r\n localStorage.setItem('sparc.science-sidebar-search-history', JSON.stringify(searchHistory));\r\n } else {\r\n localStorage.setItem('sparc.science-sidebar-search-history', JSON.stringify([{filters: filters, search: search}]));\r\n }\r\n },\r\n search: function(item) {\r\n this.$emit(\"search\", item);\r\n },\r\n selectChange: function(value) {\r\n this.selectValue = value;\r\n this.search({search: value})\r\n }\r\n },\r\n mounted: function () {\r\n this.getSearchHistory();\r\n EventBus.$on('search-changed', (data) => {\r\n this.setSearchHistory(data);\r\n })\r\n }\r\n}\r\n</script>\r\n\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/tag\";\r\n\r\n.container {\r\n}\r\n\r\n.search-tag {\r\n margin: 0 5px 5px 0;\r\n cursor: pointer;\r\n max-width: 100px;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n}\r\n\r\n.title {\r\n font-size: 14px;\r\n font-weight: bold;\r\n margin-right: 5px;\r\n // center text vertically\r\n display: flex;\r\n align-items: center;\r\n \r\n}\r\n\r\n.search-select {\r\n float: right;\r\n}\r\n</style>\r\n\r\n<style lang=\"scss\">\r\n.sidebar-search-select-popper {\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-weight: 500;\r\n font-stretch: normal;\r\n font-style: normal;\r\n line-height: normal;\r\n letter-spacing: normal;\r\n color: #292b66;\r\n}\r\n</style>","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SearchHistory.vue?vue&type=template&id=ca301f24&scoped=true&\"\nimport script from \"./SearchHistory.vue?vue&type=script&lang=js&\"\nexport * from \"./SearchHistory.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SearchHistory.vue?vue&type=style&index=0&id=ca301f24&scoped=true&lang=scss&\"\nimport style1 from \"./SearchHistory.vue?vue&type=style&index=1&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"ca301f24\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{ref:\"container\",staticClass:\"dataset-card-container\"},[_c('div',{ref:\"card\",staticClass:\"dataset-card\"},[_c('div',{staticClass:\"seperator-path\"}),_c('div',{directives:[{name:\"loading\",rawName:\"v-loading\",value:(_vm.loading),expression:\"loading\"}],staticClass:\"card\"},[_c('span',{staticClass:\"card-left\"},[(!_vm.loading && _vm.discoverId)?_c('image-gallery',{attrs:{\"datasetId\":_vm.discoverId,\"datasetVersion\":_vm.version,\"entry\":_vm.entry,\"envVars\":_vm.envVars,\"label\":_vm.label,\"datasetThumbnail\":_vm.thumbnail,\"dataset-biolucida\":_vm.biolucidaData,\"category\":_vm.currentCategory},on:{\"card-clicked\":_vm.galleryClicked}}):_vm._e()],1),_c('div',{staticClass:\"card-right\"},[_c('div',{staticClass:\"title\",on:{\"click\":_vm.cardClicked}},[_vm._v(_vm._s(_vm.entry.name))]),_c('div',{staticClass:\"details\"},[_vm._v(_vm._s(_vm.contributors)+\" \"+_vm._s(_vm.entry.publishDate ? (\"(\" + _vm.publishYear + \")\") : ''))]),_c('div',{staticClass:\"details\"},[_vm._v(_vm._s(_vm.samples))]),(!_vm.entry.detailsReady)?_c('div',{directives:[{name:\"loading\",rawName:\"v-loading\",value:(!_vm.entry.detailsReady),expression:\"!entry.detailsReady\"}],staticClass:\"details loading-icon\"}):_vm._e(),_c('div',[(_vm.entry.simulation)?_c('el-button',{staticClass:\"button\",attrs:{\"size\":\"mini\",\"icon\":\"el-icon-view\"},on:{\"click\":_vm.openRepository}},[_vm._v(\"View repository\")]):_vm._e()],1),_c('div',{staticClass:\"badges-container\"},[_c('badges-group',{attrs:{\"entry\":_vm.entry,\"dataset-biolucida\":_vm.biolucidaData},on:{\"categoryChanged\":_vm.categoryChanged}})],1)])])])])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return (_vm.categories['All'].size > 1)?_c('div',{ref:\"container\",staticClass:\"container\"},[_c('div',[_vm._v(\" View data types: \")]),_vm._l((_vm.categories),function(item,key){return [(item.size > 0)?_c('el-button',{key:key,class:[{ 'active': key == _vm.active},'tag-button'],attrs:{\"size\":\"small\"},on:{\"click\":function($event){return _vm.categoryClicked(key)}}},[_vm._v(_vm._s(key + \" (\" + item.size + \")\")+\" \")]):_vm._e()]})],2):_vm._e()}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\r\n <div v-if=\"categories['All'].size > 1\" class=\"container\" ref=\"container\">\r\n <div>\r\n View data types:\r\n </div>\r\n <template v-for=\"(item, key) in categories\" >\r\n <el-button\r\n v-if=\"item.size > 0\"\r\n :class=\"[{ 'active': key == active},'tag-button']\"\r\n @click=\"categoryClicked(key)\"\r\n size=\"small\" :key=\"key\">{{ key + \" (\" + item.size + \")\" }}\r\n </el-button>\r\n </template>\r\n </div>\r\n</template>\r\n\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport { Button } from \"element-ui\";\r\nimport lang from \"element-ui/lib/locale/lang/en\";\r\nimport locale from \"element-ui/lib/locale\";\r\n\r\nlocale.use(lang);\r\nVue.use(Button);\r\n\r\nexport default {\r\n name: \"BadgesGroup\",\r\n props: {\r\n /**\r\n * Object containing information for\r\n * the required viewing.\r\n */\r\n additionalLinks: {\r\n type: Array,\r\n default: () => {\r\n return [];\r\n },\r\n },\r\n datasetBiolucida: {\r\n type: Object,\r\n default: () => {\r\n return {};\r\n },\r\n },\r\n entry: {\r\n type: Object,\r\n default: () => {\r\n return {};\r\n },\r\n },\r\n },\r\n data: function () {\r\n return {\r\n //Always start with 1 image - the dataset thumbnail itself\r\n categories: { \"All\": {size: 1}, \"Dataset\": {size: 1} },\r\n active: \"All\"\r\n };\r\n },\r\n methods: {\r\n addToCategories: function (array, name) {\r\n if (array && array.length > 0) {\r\n this.categories[name] = { size: array.length };\r\n this.categories[\"All\"].size += array.length;\r\n }\r\n },\r\n addSimulationsToCategories: function (array) {\r\n if (array && array.length > 0) {\r\n const size = 1;\r\n this.categories[\"Simulations\"] = { size };\r\n this.categories[\"All\"].size += size;\r\n }\r\n },\r\n categoryClicked: function(name) {\r\n this.active = name;\r\n this.$emit(\"categoryChanged\", name);\r\n }\r\n },\r\n watch: {\r\n datasetBiolucida: {\r\n deep: true,\r\n immediate: true,\r\n handler: function (biolucidaData) {\r\n if (\"dataset_images\" in biolucidaData) {\r\n this.addToCategories(biolucidaData[\"dataset_images\"], \"Images\");\r\n }\r\n }\r\n },\r\n entry: {\r\n deep: true,\r\n immediate: true,\r\n handler: function () {\r\n this.addToCategories(this.entry.scaffolds, 'Scaffolds');\r\n this.addToCategories(this.entry.segmentation, 'Segmentations');\r\n this.addToCategories(this.entry.plots, 'Plots');\r\n this.addSimulationsToCategories(this.entry.simulation);\r\n /** disable the following\r\n this.addToCategories(this.entry.images, 'Images');\r\n this.addToCategories(this.entry.videos, 'Videos');\r\n **/\r\n }\r\n }\r\n },\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/button\";\r\n\r\n.tag-button,\r\n.tag-button:hover,\r\n.tag-button:focus,\r\n.tag-button.active\r\n{\r\n border-radius: 4px;\r\n font-size: 0.75rem;\r\n padding: 0.2rem 0.2rem;\r\n margin: 0.5rem 0 0 0;\r\n margin-right: 0.75rem!important;\r\n}\r\n\r\n.tag-button,\r\n.tag-button:hover,\r\n.tag-button:focus\r\n{\r\n background: #f9f2fc;\r\n border: 1px solid $app-primary-color;\r\n color: $app-primary-color;\r\n}\r\n\r\n.tag-button.active\r\n{\r\n background: $app-primary-color;\r\n border: 1px solid $app-primary-color;\r\n color: #fff;\r\n}\r\n\r\n.tag-button+.tag-button\r\n{\r\n margin-left:0;\r\n}\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BadgesGroup.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BadgesGroup.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./BadgesGroup.vue?vue&type=template&id=3f3b3b02&scoped=true&\"\nimport script from \"./BadgesGroup.vue?vue&type=script&lang=js&\"\nexport * from \"./BadgesGroup.vue?vue&type=script&lang=js&\"\nimport style0 from \"./BadgesGroup.vue?vue&type=style&index=0&id=3f3b3b02&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"3f3b3b02\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"full-size\"},[_c('gallery',{ref:\"gallery\",attrs:{\"bottomSpacer\":_vm.bottomSpacer,\"cardWidth\":10,\"items\":_vm.galleryItems,\"max-width\":_vm.maxWidth,\"show-indicator-bar\":false,\"show-card-details\":true,\"highlight-active\":false,\"image-style\":_vm.imageStyle,\"image-container-style\":_vm.imageContainerStyle,\"body-style\":_vm.bodyStyle,\"shadow\":_vm.shadow},on:{\"card-clicked\":_vm.cardClicked}})],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","export default function _iterableToArrayLimit(arr, i) {\n if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === \"[object Arguments]\")) {\n return;\n }\n\n var _arr = [];\n var _n = true;\n var _d = false;\n var _e = undefined;\n\n try {\n for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}","import arrayWithHoles from \"./arrayWithHoles\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit\";\nimport nonIterableRest from \"./nonIterableRest\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || nonIterableRest();\n}","<script>\r\nexport default {\r\n name: \"S3Bucket\",\r\n data() {\r\n return {\r\n s3Bucket: undefined,\r\n };\r\n },\r\n methods: {\r\n updateS3Bucket: function(s3uri) {\r\n this.s3Bucket = undefined;\r\n if (s3uri) {\r\n const substring = s3uri.split(\"//\")[1];\r\n if (substring) {\r\n this.s3Bucket = substring.split(\"/\")[0];\r\n return;\r\n }\r\n }\r\n },\r\n getS3Args: function() {\r\n if (this.s3Bucket) {\r\n return `?s3BucketName=${this.s3Bucket}`\r\n }\r\n return \"\";\r\n },\r\n },\r\n\r\n};\r\n</script>\r\n\r\n\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./S3Bucket.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./S3Bucket.vue?vue&type=script&lang=js&\"","var render, staticRenderFns\nimport script from \"./S3Bucket.vue?vue&type=script&lang=js&\"\nexport * from \"./S3Bucket.vue?vue&type=script&lang=js&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports","<template>\r\n <div class=\"full-size\">\r\n <gallery\r\n :bottomSpacer=\"bottomSpacer\"\r\n :cardWidth=\"10\"\r\n :items=\"galleryItems\"\r\n :max-width=\"maxWidth\"\r\n :show-indicator-bar=\"false\"\r\n :show-card-details=\"true\"\r\n :highlight-active=\"false\"\r\n :image-style=\"imageStyle\"\r\n :image-container-style=\"imageContainerStyle\"\r\n :body-style=\"bodyStyle\"\r\n :shadow=\"shadow\"\r\n @card-clicked=\"cardClicked\"\r\n ref=\"gallery\"\r\n />\r\n </div>\r\n</template>\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nconst baseName = (str) => {\r\n return str.split(\"\\\\\").pop().split(\"/\").pop();\r\n};\r\n\r\nconst capitalise = function (string) {\r\n return string.replace(/\\b\\w/g, (v) => v.toUpperCase());\r\n};\r\n\r\nimport GalleryHelper from \"@abi-software/gallery/src/mixins/GalleryHelpers\";\r\nimport Gallery from \"@abi-software/gallery/src/main-bundle.js\";\r\n//provide the s3Bucket related methods and data.\r\nimport S3Bucket from \"../mixins/S3Bucket\";\r\n\r\nexport default {\r\n name: \"ImageGallery\",\r\n components: { Gallery },\r\n mixins: [GalleryHelper, S3Bucket],\r\n props: {\r\n datasetBiolucida: {\r\n type: Object,\r\n default: () => {\r\n return {};\r\n },\r\n },\r\n envVars: {\r\n type: Object,\r\n default: () => {},\r\n },\r\n label: {\r\n type: String,\r\n default: \"\",\r\n },\r\n plots: {\r\n type: Array,\r\n default: () => {\r\n return [];\r\n },\r\n },\r\n datasetId: {\r\n type: Number,\r\n default: -1,\r\n },\r\n datasetVersion: {\r\n type: Number,\r\n default: -1,\r\n },\r\n datasetThumbnail: {\r\n type: String,\r\n default: \"\",\r\n },\r\n category: {\r\n type: String,\r\n default: \"All\",\r\n },\r\n entry: {\r\n type: Object,\r\n default: () => {\r\n return {};\r\n },\r\n },\r\n },\r\n data() {\r\n return {\r\n currentIndex: 0,\r\n ro: null,\r\n maxWidth: 3,\r\n items: {\r\n //Use the Images instead for Biolucida Images\r\n //\"Biolucida Images\": [],\r\n 'Dataset': [],\r\n 'Images': [],\r\n 'Scaffolds': [],\r\n 'Segmentations': [],\r\n 'Simulations': [],\r\n 'Videos': [],\r\n 'Plots': [],\r\n },\r\n bodyStyle: { padding: '0px', background: '#ffffff' },\r\n imageContainerStyle: {\r\n width: '160px',\r\n height: '160px',\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n },\r\n imageStyle: { maxWidth: '160px', maxHeight: '160px'},\r\n shadow: \"never\",\r\n bottomSpacer: { minHeight: '0rem' },\r\n resetIndex: false,\r\n };\r\n },\r\n methods: {\r\n cardClicked: function(payload) {\r\n this.$emit('card-clicked', payload);\r\n },\r\n createSciCurnchItems: function () {\r\n this.updateS3Bucket(this.entry.s3uri);\r\n this.createDatasetItem();\r\n this.createScaffoldItems();\r\n this.createSimulationItems();\r\n this.createPlotItems();\r\n this.createSegmentationItems();\r\n /* Disable these two\r\n this.createImageItems();\r\n this.createVideoItems();\r\n */\r\n },\r\n createDatasetItem: function () {\r\n const link = `${this.envVars.ROOT_URL}/datasets/${this.datasetId}?type=dataset`\r\n if (this.datasetThumbnail) {\r\n this.items['Dataset'].push({\r\n id: -1,\r\n //Work around gallery requires a truthy string\r\n title: \" \",\r\n type: `Dataset ${this.datasetId}`,\r\n thumbnail: this.datasetThumbnail,\r\n link,\r\n hideType: true,\r\n hideTitle: true,\r\n });\r\n }\r\n },\r\n createImageItems: function () {\r\n if (this.entry.images) {\r\n this.entry.images.forEach((image) => {\r\n const filePath = image.dataset.path;\r\n const id = image.identifier;\r\n const linkUrl = `${this.envVars.ROOT_URL}/datasets/imageviewer?dataset_id=${this.datasetId}&dataset_version=${this.datasetVersion}&file_path=${filePath}&mimetype=${image.mimetype.name}`;\r\n this.items['Images'].push({\r\n id,\r\n title: baseName(filePath),\r\n type: \"Image\",\r\n link: linkUrl,\r\n hideType: true,\r\n });\r\n });\r\n }\r\n },\r\n createPlotItems: function () {\r\n if (this.entry.plots) {\r\n this.entry.plots.forEach((plot) => {\r\n const filePath = plot.dataset.path;\r\n const id = plot.identifier;\r\n const thumbnail = this.getThumbnailForPlot(plot, this.entry.thumbnails);\r\n let thumbnailURL = undefined;\r\n let mimetype = '';\r\n if (thumbnail) {\r\n thumbnailURL = this.getImageURLFromS3(this.envVars.API_LOCATION, {\r\n id,\r\n datasetId: this.datasetId,\r\n datasetVersion: this.datasetVersion,\r\n file_path: thumbnail.dataset.path,\r\n s3Bucket: this.s3Bucket,\r\n });\r\n mimetype = thumbnail.mimetype.name;\r\n }\r\n const plotAnnotation = plot.datacite;\r\n const filePathPrefix = `${this.envVars.API_LOCATION}/s3-resource/${this.datasetId}/${this.datasetVersion}/files/`;\r\n const sourceUrl = filePathPrefix + plot.dataset.path + this.getS3Args();\r\n\r\n //plotAnnotation.supplemental_json_metadata.description can be undefined or\r\n //contain an empty string causing an error with JSON.parse\r\n let metadata = {};\r\n try { \r\n metadata = JSON.parse(\r\n plotAnnotation.supplemental_json_metadata.description\r\n );\r\n } catch (error) {\r\n console.warn(error);\r\n }\r\n\r\n let supplementalData = [];\r\n if (plotAnnotation.isDescribedBy) {\r\n supplementalData.push({\r\n url: filePathPrefix + plotAnnotation.isDescribedBy.path\r\n });\r\n }\r\n\r\n const resource = {\r\n dataSource: {url: sourceUrl},\r\n metadata,\r\n supplementalData\r\n }\r\n\r\n let action = {\r\n label: capitalise(this.label),\r\n resource: resource,\r\n s3uri: this.entry.s3uri,\r\n title: \"View plot\",\r\n type: \"Plot\",\r\n discoverId: this.discoverId,\r\n version: this.datasetVersion,\r\n };\r\n this.items['Plots'].push({\r\n id,\r\n title: baseName(filePath),\r\n type: \"Plot\",\r\n thumbnail: thumbnailURL,\r\n userData: action,\r\n hideType: true,\r\n mimetype\r\n });\r\n });\r\n }\r\n },\r\n createScaffoldItems: function () {\r\n if (this.entry.scaffolds) {\r\n let index = 0;\r\n this.entry.scaffolds.forEach((scaffold, i) => {\r\n const filePath = scaffold.dataset.path;\r\n const id = scaffold.identifier;\r\n const thumbnail = this.getThumbnailForScaffold(\r\n scaffold,\r\n this.entry.scaffoldViews,\r\n this.entry.thumbnails,\r\n index\r\n );\r\n let mimetype = '';\r\n let thumbnailURL = undefined;\r\n if (thumbnail) {\r\n thumbnailURL = this.getImageURLFromS3(this.envVars.API_LOCATION, {\r\n id,\r\n datasetId: this.datasetId,\r\n datasetVersion: this.datasetVersion,\r\n file_path: thumbnail.dataset.path,\r\n s3Bucket: this.s3Bucket,\r\n });\r\n mimetype = thumbnail.mimetype.name;\r\n }\r\n let action = {\r\n label: capitalise(this.label),\r\n resource: `${this.envVars.API_LOCATION}s3-resource/${this.datasetId}/${this.datasetVersion}/files/${filePath}${this.getS3Args()}`,\r\n title: \"View 3D scaffold\",\r\n type: \"Scaffold\",\r\n discoverId: this.datasetId,\r\n apiLocation: this.envVars.API_LOCATION,\r\n version: this.datasetVersion,\r\n banner: this.datasetThumbnail,\r\n s3uri: this.entry.s3uri,\r\n contextCardUrl: this.getContextCardUrl(i)\r\n };\r\n this.items['Scaffolds'].push({\r\n id,\r\n title: baseName(filePath),\r\n type: \"Scaffold\",\r\n thumbnail: thumbnailURL,\r\n userData: action,\r\n hideType: true,\r\n mimetype\r\n });\r\n });\r\n }\r\n },\r\n createSegmentationItems: function () {\r\n if (this.entry.segmentation) {\r\n this.entry.segmentation.forEach((segmentation) => {\r\n const id = segmentation.id;\r\n let filePath = segmentation.dataset.path;\r\n filePath = filePath.replaceAll(\" \", \"_\");\r\n filePath = filePath.replaceAll(\",\", \"_\");\r\n const prefix = this.envVars.NL_LINK_PREFIX;\r\n const resource = {\r\n share_link: `${prefix}/dataviewer?datasetId=${this.datasetId}&version=${this.datasetVersion}&path=files/${filePath}`,\r\n };\r\n let action = {\r\n label: capitalise(this.label),\r\n resource: resource,\r\n datasetId: this.datasetId,\r\n s3uri: this.entry.s3uri,\r\n title: \"View segmentation\",\r\n type: \"Segmentation\",\r\n };\r\n const thumbnailURL = this.getSegmentationThumbnailURL(\r\n this.envVars.API_LOCATION,\r\n {\r\n id,\r\n datasetId: this.datasetId,\r\n datasetVersion: this.datasetVersion,\r\n segmentationFilePath: filePath,\r\n s3Bucket: this.s3Bucket,\r\n }\r\n );\r\n this.items['Segmentations'].push({\r\n id,\r\n title: baseName(filePath),\r\n type: \"Segmentation\",\r\n thumbnail: thumbnailURL,\r\n userData: action,\r\n hideType: true,\r\n mimetype: 'image/png',\r\n });\r\n });\r\n }\r\n },\r\n createSimulationItems: function () {\r\n if (this.entry.simulation && this.entry.simulation.length > 0) {\r\n let action = {\r\n label: undefined,\r\n apiLocation: this.envVars.API_LOCATION,\r\n s3uri: this.entry.s3uri,\r\n version: this.datasetVersion,\r\n title: \"View simulation\",\r\n type: \"Simulation\",\r\n name: this.entry.name,\r\n description: this.entry.description,\r\n discoverId: this.datasetId,\r\n dataset: `${this.envVars.ROOT_URL}/datasets/${this.datasetId}?type=dataset`\r\n };\r\n this.items['Simulations'].push({\r\n id: \"simulation\",\r\n title: \" \",\r\n type: \"Simulation\",\r\n hideType: true,\r\n hideTitle: true,\r\n userData: action,\r\n });\r\n }\r\n },\r\n createVideoItems: function () {\r\n if (this.entry.videos) {\r\n this.entry.videos.forEach((video) => {\r\n const filePath = this.getS3FilePath(\r\n this.datasetId,\r\n this.datasetVersion,\r\n video.dataset.path\r\n );\r\n const linkUrl = `${this.envVars.ROOT_URL}/datasets/videoviewer?dataset_version=${this.datasetVersion}&dataset_id=${this.datasetId}&file_path=${filePath}&mimetype=${video.mimetype.name}`;\r\n this.items['Videos'].push({\r\n title: video.name,\r\n type: \"Video\",\r\n thumbnail: this.defaultVideoImg,\r\n hideType: true,\r\n link: linkUrl,\r\n });\r\n });\r\n }\r\n },\r\n onResize: function () {\r\n this.maxWidth = this.$el.clientWidth;\r\n // this.$emit('resize', this.$el.clientWidth)\r\n },\r\n getContextCardUrl(scaffoldIndex){\r\n if(!this.entry.contextualInformation || this.entry.contextualInformation.length == 0){\r\n return undefined\r\n } else {\r\n // The line below checks if there is a context file for each scaffold. If there is not, we use the first context card for each scaffold.\r\n let contextIndex = this.entry['abi-contextual-information'].length == this.entry.scaffolds.length ? scaffoldIndex : 0\r\n return `${this.envVars.API_LOCATION}s3-resource/${this.datasetId}/${this.datasetVersion}/files/${this.entry.contextualInformation[contextIndex]}${this.getS3Args()}`\r\n }\r\n }\r\n },\r\n computed: {\r\n galleryItems() {\r\n if (this.resetIndex) {\r\n this.$refs.gallery.indicatorClicked(0);\r\n }\r\n let items = [...this.items[\"Dataset\"]];\r\n if (this.category === \"All\") {\r\n for (const [key, value] of Object.entries(this.items)) {\r\n if (key !== \"Dataset\")\r\n items = items.concat(value);\r\n }\r\n return items;\r\n }\r\n else\r\n return this.items[this.category];\r\n },\r\n },\r\n created: function () {\r\n this.createSciCurnchItems();\r\n },\r\n watch: {\r\n category: function() {\r\n this.resetIndex = true;\r\n },\r\n galleryItems: function() {\r\n this.resetIndex = false;\r\n },\r\n datasetBiolucida: {\r\n deep: true,\r\n immediate: true,\r\n handler: function (biolucidaData) {\r\n let items = [];\r\n if (\"dataset_images\" in biolucidaData) {\r\n items.push(\r\n ...Array.from(biolucidaData.dataset_images, (dataset_image) => {\r\n const thumbnailURL = this.getThumbnailURLFromBiolucida(\r\n this.envVars.API_LOCATION,\r\n {\r\n id: dataset_image.image_id,\r\n }\r\n );\r\n const resource = {\r\n share_link: dataset_image.share_link,\r\n id: dataset_image.image_id,\r\n itemId: dataset_image.sourcepkg_id,\r\n };\r\n let action = {\r\n label: capitalise(this.label),\r\n resource: resource,\r\n datasetId: this.datasetId,\r\n title: \"View image\",\r\n name: capitalise(this.label),\r\n type: \"Biolucida\",\r\n };\r\n return {\r\n id: dataset_image.image_id,\r\n title: `Image`,\r\n type: \"Image\",\r\n thumbnail: thumbnailURL,\r\n userData: action,\r\n mimetype: 'image/png',\r\n hideType: true,\r\n };\r\n })\r\n );\r\n }\r\n this.items['Images'] = items;\r\n },\r\n },\r\n },\r\n mounted() {\r\n this.ro = new ResizeObserver(this.onResize).observe(this.$el);\r\n },\r\n destroyed() {\r\n delete this.ro;\r\n },\r\n};\r\n</script>\r\n\r\n<style scoped lang=\"scss\">\r\n.full-size {\r\n height: 100%;\r\n width: 244px;\r\n}\r\n\r\n.key-image-span.active {\r\n transform: scale(1.16);\r\n border: 4px $app-primary-color solid;\r\n}\r\n\r\n.key-image-span {\r\n display: flex;\r\n position: relative;\r\n}\r\n\r\n.overlay {\r\n position: absolute;\r\n right: 5px;\r\n top: 5px;\r\n width: 1.61em;\r\n height: 1em;\r\n border-radius: 3px;\r\n opacity: 0.8;\r\n}\r\n\r\nimg {\r\n vertical-align: bottom;\r\n}\r\n\r\na.prev,\r\na.next {\r\n display: flex;\r\n font-size: 3em;\r\n}\r\n\r\na.prev:not(.underline),\r\na.next:not(.underline) {\r\n text-decoration: none;\r\n}\r\n\r\na.prev {\r\n justify-content: flex-start;\r\n}\r\n\r\na.next {\r\n justify-content: flex-end;\r\n}\r\n\r\n.standard-gallery {\r\n display: flex;\r\n flex-wrap: nowrap;\r\n justify-content: space-around;\r\n align-items: center;\r\n}\r\n\r\n.image-line {\r\n display: flex;\r\n margin-top: 1%;\r\n margin-bottom: 1%;\r\n flex-grow: 1;\r\n justify-content: space-between;\r\n}\r\n.disabled {\r\n opacity: 0.2;\r\n cursor: default;\r\n}\r\n\r\n.rectangle {\r\n height: 1em;\r\n width: 2em;\r\n border-radius: 3px;\r\n background-color: #555;\r\n}\r\n\r\n.full-size ::v-deep .el-card {\r\n border: 0px;\r\n}\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ImageGallery.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ImageGallery.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./ImageGallery.vue?vue&type=template&id=31f0d189&scoped=true&\"\nimport script from \"./ImageGallery.vue?vue&type=script&lang=js&\"\nexport * from \"./ImageGallery.vue?vue&type=script&lang=js&\"\nimport style0 from \"./ImageGallery.vue?vue&type=style&index=0&id=31f0d189&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"31f0d189\",\n null\n \n)\n\nexport default component.exports","<template>\r\n <div class=\"dataset-card-container\" ref=\"container\">\r\n <div class=\"dataset-card\" ref=\"card\">\r\n <div class=\"seperator-path\"></div>\r\n <div v-loading=\"loading\" class=\"card\" >\r\n <span class=\"card-left\">\r\n <image-gallery v-if=\"!loading && discoverId\" \r\n :datasetId=\"discoverId\"\r\n :datasetVersion=\"version\"\r\n :entry=\"entry\"\r\n :envVars=\"envVars\"\r\n :label=\"label\"\r\n :datasetThumbnail=\"thumbnail\"\r\n :dataset-biolucida=\"biolucidaData\"\r\n :category=\"currentCategory\"\r\n @card-clicked=\"galleryClicked\"\r\n />\r\n </span>\r\n <div class=\"card-right\" >\r\n <div class=\"title\" @click=\"cardClicked\">{{entry.name}}</div>\r\n <div class=\"details\">{{contributors}} {{entry.publishDate ? `(${publishYear})` : ''}}</div>\r\n <div class=\"details\">{{samples}}</div>\r\n <div v-if=\"!entry.detailsReady\" class=\"details loading-icon\" v-loading=\"!entry.detailsReady\"></div>\r\n <div>\r\n <el-button v-if=\"entry.simulation\" @click=\"openRepository\" size=\"mini\" class=\"button\" icon=\"el-icon-view\">View repository</el-button>\r\n </div>\r\n <div class=\"badges-container\">\r\n <badges-group\r\n :entry=\"entry\"\r\n :dataset-biolucida=\"biolucidaData\"\r\n @categoryChanged=\"categoryChanged\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport BadgesGroup from \"./BadgesGroup.vue\";\r\nimport { Button, Icon } from \"element-ui\";\r\nimport lang from \"element-ui/lib/locale/lang/en\";\r\nimport locale from \"element-ui/lib/locale\";\r\nimport EventBus from \"./EventBus\"\r\nimport speciesMap from \"./species-map\";\r\nimport ImageGallery from \"./ImageGallery.vue\";\r\n\r\nlocale.use(lang);\r\nVue.use(Button);\r\nVue.use(Icon);\r\n\r\nexport default {\r\n name: \"DatasetCard\",\r\n components: { BadgesGroup, ImageGallery },\r\n props: {\r\n /**\r\n * Object containing information for\r\n * the required viewing.\r\n */\r\n entry: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n envVars: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n },\r\n data: function () {\r\n return {\r\n thumbnail: require('@/../assets/missing-image.svg'),\r\n dataLocation: this.entry.doi,\r\n discoverId: undefined,\r\n loading: true,\r\n version: 1,\r\n lastDoi: undefined,\r\n biolucidaData: undefined,\r\n currentCategory: \"All\"\r\n };\r\n },\r\n computed: {\r\n contributors: function() {\r\n let text = \"\";\r\n if (this.entry.contributors) {\r\n if (this.entry.contributors.length === 1) {\r\n text = this.lastName(this.entry.contributors[0].name);\r\n } else if (this.entry.contributors.length === 2) {\r\n text = this.lastName(this.entry.contributors[0].name) + \" & \" + this.lastName(this.entry.contributors[1].name);\r\n } else if (this.entry.contributors.length > 2) {\r\n text = this.lastName(this.entry.contributors[0].name) + \" et al.\";\r\n }\r\n }\r\n return text;\r\n },\r\n samples: function() {\r\n let text = \"\";\r\n if (this.entry.species) {\r\n if (speciesMap[this.entry.species[0].toLowerCase()]){\r\n text = `${speciesMap[this.entry.species[0].toLowerCase()]}`;\r\n } else {\r\n text = `${this.entry.species}`;\r\n }\r\n }\r\n if (this.entry.numberSamples > 0) {\r\n text += \" (\";\r\n if (this.entry.numberSamples === 1) {\r\n text += `${this.entry.numberSamples} sample`;\r\n } else if (this.entry.numberSamples > 1) {\r\n text += `${this.entry.numberSamples} samples`;\r\n }\r\n if (this.entry.numberSubjects === 1) {\r\n text += ` from ${this.entry.numberSubjects} subject`;\r\n } else if (this.entry.numberSamples > 1) {\r\n text += ` from ${this.entry.numberSubjects} subjects`;\r\n }\r\n text += \")\";\r\n }\r\n\r\n return text;\r\n },\r\n label: function(){\r\n return this.entry.organs ? this.entry.organs[0] : this.entry.name\r\n },\r\n publishYear: function() {\r\n return this.entry.publishDate.split('-')[0]\r\n }\r\n },\r\n methods: {\r\n cardClicked: function(){\r\n this.openDataset()\r\n },\r\n categoryChanged: function(name) {\r\n this.currentCategory = name;\r\n },\r\n galleryClicked: function(payload) {\r\n this.propogateCardAction(payload)\r\n },\r\n openDataset: function(){\r\n window.open(this.dataLocation,'_blank');\r\n },\r\n openRepository: function() {\r\n let apiLocation = this.envVars.API_LOCATION;\r\n this.entry.additionalLinks.forEach(function(el) {\r\n if (el.description == \"Repository\") {\r\n let xmlhttp = new XMLHttpRequest();\r\n xmlhttp.open(\"POST\", apiLocation + \"/pmr_latest_exposure\", true);\r\n xmlhttp.setRequestHeader(\"Content-type\", \"application/json\");\r\n xmlhttp.onreadystatechange = () => {\r\n if (xmlhttp.readyState === 4) {\r\n let url = \"\";\r\n if (xmlhttp.status === 200) {\r\n url = JSON.parse(xmlhttp.responseText)[\"url\"];\r\n }\r\n if (url === \"\") {\r\n url = el.uri;\r\n }\r\n window.open(url,'_blank');\r\n }\r\n };\r\n xmlhttp.send(JSON.stringify({workspace_url: el.uri}));\r\n }\r\n });\r\n },\r\n propogateCardAction: function(action){\r\n EventBus.$emit(\"PopoverActionClick\", action)\r\n EventBus.$emit(\"contextUpdate\", action) // Pass to mapintegratedvuer\r\n },\r\n splitDOI: function(doi){\r\n return [doi.split('/')[doi.split('/').length-2], doi.split('/')[doi.split('/').length-1]]\r\n },\r\n getBanner: function () {\r\n // Only load banner if card has changed\r\n if (this.lastDoi !== this.entry.doi) {\r\n this.lastDoi = this.entry.doi\r\n this.loading = true\r\n let doi = this.splitDOI(this.entry.doi)\r\n fetch(`${this.envVars.PENNSIEVE_API_LOCATION}/discover/datasets/doi/${doi[0]}/${doi[1]}`)\r\n .then((response) =>{\r\n if (!response.ok){\r\n throw Error(response.statusText)\r\n } else {\r\n return response.json()\r\n }\r\n })\r\n .then((data) => {\r\n this.thumbnail = data.banner\r\n this.discoverId = data.id\r\n this.version = data.version\r\n this.dataLocation = `https://sparc.science/datasets/${data.id}?type=dataset`\r\n this.getBiolucidaInfo(this.discoverId)\r\n this.loading = false\r\n })\r\n .catch(() => {\r\n //set defaults if we hit an error\r\n this.thumbnail = require('@/../assets/missing-image.svg')\r\n this.discoverId = Number(this.entry.datasetId)\r\n this.loading = false\r\n });\r\n }\r\n\r\n },\r\n lastName: function(fullName){\r\n return fullName.split(',')[0]\r\n },\r\n getBiolucidaInfo: function(id) {\r\n let apiLocation = this.envVars.API_LOCATION;\r\n let endpoint = apiLocation + \"image_search/\" + id;\r\n // Add parameters if we are sent them\r\n fetch(endpoint)\r\n .then(response => response.json())\r\n .then(data => {\r\n if (data.status == \"success\")\r\n this.biolucidaData = data;\r\n });\r\n }\r\n },\r\n created: function() {\r\n this.getBanner()\r\n },\r\n watch: {\r\n // currently not using card overflow\r\n 'entry.description': function() { // watch it\r\n this.getBanner()\r\n }\r\n },\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/col\";\r\n@import \"~element-ui/packages/theme-chalk/src/loading\";\r\n\r\n.dataset-card {\r\n padding-left: 16px;\r\n position: relative;\r\n min-height:17rem;\r\n}\r\n\r\n.title {\r\n padding-bottom: 0.75rem;\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-weight: bold;\r\n font-stretch: normal;\r\n font-style: normal;\r\n line-height: 1.5;\r\n letter-spacing: 1.05px;\r\n color: #484848;\r\n cursor: pointer;\r\n}\r\n.card {\r\n padding-top: 18px;\r\n position: relative;\r\n display: flex;\r\n}\r\n\r\n.card-left{\r\n flex: 1\r\n}\r\n\r\n.card-right {\r\n flex: 1.3;\r\n padding-left: 6px;\r\n}\r\n\r\n.button{\r\n z-index: 10;\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-weight: normal;\r\n font-stretch: normal;\r\n font-style: normal;\r\n line-height: normal;\r\n letter-spacing: normal;\r\n background-color: $app-primary-color;\r\n border: $app-primary-color;\r\n color: white;\r\n cursor: pointer;\r\n margin-top: 8px;\r\n}\r\n\r\n.button:hover {\r\n background-color: $app-primary-color;\r\n color: white;\r\n}\r\n\r\n.banner-img {\r\n width: 128px;\r\n height: 128px;\r\n box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.25);\r\n background-color: #ffffff;\r\n cursor: pointer;\r\n}\r\n.details{\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-weight: normal;\r\n font-stretch: normal;\r\n font-style: normal;\r\n line-height: 1.5;\r\n letter-spacing: 1.05px;\r\n color: #484848;\r\n}\r\n\r\n.badges-container {\r\n margin-top:0.75rem;\r\n}\r\n\r\n.loading-icon {\r\n z-index: 20;\r\n width: 40px;\r\n height: 40px;\r\n left: 80px;\r\n}\r\n\r\n.loading-icon ::v-deep .el-loading-mask {\r\n background-color: rgba(117, 190, 218, 0.0) !important;\r\n}\r\n\r\n.loading-icon ::v-deep .el-loading-spinner .path {\r\n stroke: $app-primary-color;\r\n}\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./DatasetCard.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./DatasetCard.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./DatasetCard.vue?vue&type=template&id=b08ebd76&scoped=true&\"\nimport script from \"./DatasetCard.vue?vue&type=script&lang=js&\"\nexport * from \"./DatasetCard.vue?vue&type=script&lang=js&\"\nimport style0 from \"./DatasetCard.vue?vue&type=style&index=0&id=b08ebd76&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"b08ebd76\",\n null\n \n)\n\nexport default component.exports","<template>\r\n <el-card :body-style=\"bodyStyle\" class=\"content-card\">\r\n <div slot=\"header\" class=\"header\">\r\n <el-input\r\n class=\"search-input\"\r\n placeholder=\"Search\"\r\n v-model=\"searchInput\"\r\n @keyup.native=\"searchEvent\"\r\n clearable\r\n @clear=\"clearSearchClicked\"\r\n ></el-input>\r\n <el-button class=\"button\" @click=\"searchEvent\">Search</el-button>\r\n </div>\r\n <SearchFilters\r\n class=\"filters\"\r\n ref=\"filtersRef\"\r\n :entry=\"filterEntry\"\r\n :envVars=\"envVars\"\r\n @filterResults=\"filterUpdate\"\r\n @numberPerPage=\"numberPerPageUpdate\"\r\n @loading=\"filtersLoading\"\r\n @cascaderReady=\"cascaderReady\"\r\n ></SearchFilters>\r\n <search-history ref=\"searchHistory\" @search=\"searchHistorySearch\"></search-history>\r\n <div class=\"content scrollbar\" v-loading=\"loadingCards\" ref=\"content\">\r\n <div class=\"error-feedback\" v-if=\"results.length === 0 && !loadingCards\">\r\n No results found - Please change your search / filter criteria.\r\n </div>\r\n <div v-for=\"result in results\" :key=\"result.doi\" class=\"step-item\">\r\n <DatasetCard\r\n :entry=\"result\"\r\n :envVars=\"envVars\"\r\n ></DatasetCard>\r\n </div>\r\n <el-pagination\r\n class=\"pagination\"\r\n :current-page.sync=\"page\"\r\n hide-on-single-page\r\n large\r\n layout=\"prev, pager, next\"\r\n :page-size=\"numberPerPage\"\r\n :total=\"numberOfHits\"\r\n @current-change=\"pageChange\"\r\n ></el-pagination>\r\n </div>\r\n </el-card>\r\n</template>\r\n\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport {\r\n Button,\r\n Card,\r\n Drawer,\r\n Icon,\r\n Input,\r\n Loading,\r\n Pagination,\r\n} from \"element-ui\";\r\nimport lang from \"element-ui/lib/locale/lang/en\";\r\nimport locale from \"element-ui/lib/locale\";\r\nimport SearchFilters from \"./SearchFilters\";\r\nimport SearchHistory from \"./SearchHistory\";\r\nimport DatasetCard from \"./DatasetCard\";\r\nimport EventBus from \"./EventBus\";\r\n\r\nimport { AlgoliaClient } from \"../algolia/algolia.js\";\r\nimport { getFilters, facetPropPathMapping } from \"../algolia/utils.js\";\r\n\r\nlocale.use(lang);\r\nVue.use(Button);\r\nVue.use(Card);\r\nVue.use(Drawer);\r\nVue.use(Icon);\r\nVue.use(Input);\r\nVue.use(Loading);\r\nVue.use(Pagination);\r\n\r\n// handleErrors: A custom fetch error handler to recieve messages from the server\r\n// even when an error is found\r\nvar handleErrors = async function (response) {\r\n if (!response.ok) {\r\n let parse = await response.json();\r\n if (parse) {\r\n throw new Error(parse.message);\r\n } else {\r\n throw new Error(response);\r\n }\r\n }\r\n return response;\r\n};\r\n\r\nvar initial_state = {\r\n searchInput: \"\",\r\n lastSearch: \"\",\r\n results: [],\r\n numberOfHits: 0,\r\n filter: [],\r\n loadingCards: false,\r\n numberPerPage: 10,\r\n page: 1,\r\n pageModel: 1,\r\n start: 0,\r\n hasSearched: false,\r\n contextCardEnabled: false,\r\n};\r\n\r\nexport default {\r\n components: { SearchFilters, DatasetCard, SearchHistory },\r\n name: \"SideBarContent\",\r\n props: {\r\n visible: {\r\n type: Boolean,\r\n default: false,\r\n },\r\n isDrawer: {\r\n type: Boolean,\r\n default: true,\r\n },\r\n entry: {\r\n type: Object,\r\n default: () => initial_state,\r\n },\r\n envVars: {\r\n type: Object,\r\n default: () => {},\r\n },\r\n },\r\n data: function () {\r\n return {\r\n ...this.entry,\r\n bodyStyle: {\r\n flex: \"1 1 auto\",\r\n \"flex-flow\": \"column\",\r\n display: \"flex\",\r\n },\r\n cascaderIsReady: false,\r\n };\r\n },\r\n computed: {\r\n // This computed property populates filter data's entry object with $data from this sidebar\r\n filterEntry: function () {\r\n return {\r\n numberOfHits: this.numberOfHits,\r\n filterFacets: this.filter,\r\n };\r\n },\r\n },\r\n methods: {\r\n resetSearch: function () {\r\n this.numberOfHits = 0;\r\n this.discoverIds = [];\r\n this._dois = [];\r\n this.results = [];\r\n this.loadingCards = false;\r\n },\r\n openSearch: function (filter, search = \"\") {\r\n this.searchInput = search;\r\n this.resetPageNavigation();\r\n //Proceed normally if cascader is ready\r\n if (this.cascaderIsReady) {\r\n this.filter = this.$refs.filtersRef.getValidatedFilters(filter);\r\n //Facets provided but cannot find at least one valid\r\n //facet. Tell the users the search is invalid and reset\r\n //facets check boxes.\r\n if (\r\n filter &&\r\n filter.length > 0 &&\r\n this.filter &&\r\n this.filter.length === 0\r\n ) {\r\n this.$refs.filtersRef.checkShowAllBoxes();\r\n this.resetSearch();\r\n } else if (this.filter) {\r\n this.searchAlgolia(this.filter, search);\r\n this.$refs.filtersRef.setCascader(this.filter);\r\n }\r\n } else {\r\n //cascader is not ready, perform search if no filter is set,\r\n //otherwise waith for cascader to be ready\r\n this.filter = filter;\r\n if (!filter || filter.length == 0) {\r\n this.searchAlgolia(this.filter, search);\r\n }\r\n }\r\n },\r\n addFilter: function (filter) {\r\n if (this.cascaderIsReady) {\r\n this.resetPageNavigation();\r\n if (filter) {\r\n if (this.$refs.filtersRef.addFilter(filter))\r\n this.$refs.filtersRef.initiateSearch();\r\n }\r\n } else {\r\n if (Array.isArray(this.filter)) {\r\n this.filter.push(filter);\r\n } else {\r\n this.filter = [filter];\r\n }\r\n }\r\n },\r\n cascaderReady: function () {\r\n this.cascaderIsReady = true;\r\n this.openSearch(this.filter, this.searchInput);\r\n },\r\n clearSearchClicked: function () {\r\n this.searchInput = \"\";\r\n this.resetPageNavigation();\r\n this.searchAlgolia(this.filters, this.searchInput);\r\n this.$refs.searchHistory.selectValue = 'Full search history'\r\n },\r\n searchEvent: function (event = false) {\r\n if (event.keyCode === 13 || event instanceof MouseEvent) {\r\n this.resetPageNavigation();\r\n this.searchAlgolia(this.filters, this.searchInput);\r\n this.$refs.searchHistory.selectValue = 'Full search history'\r\n this.$refs.searchHistory.addSearchToHistory(this.filters, this.searchInput);\r\n }\r\n },\r\n filterUpdate: function (filters) {\r\n this.filters = [...filters];\r\n this.resetPageNavigation();\r\n this.searchAlgolia(filters, this.searchInput);\r\n this.$emit(\"search-changed\", {\r\n value: filters,\r\n type: \"filter-update\",\r\n });\r\n },\r\n searchAlgolia(filters, query = \"\") {\r\n // Algolia search\r\n this.loadingCards = true;\r\n this.algoliaClient\r\n .anatomyInSearch(getFilters(filters), query)\r\n .then((anatomy) => {\r\n EventBus.$emit(\"available-facets\", {\r\n 'uberons': anatomy,\r\n 'labels': this.algoliaClient.anatomyFacetLabels\r\n });\r\n });\r\n this.algoliaClient\r\n .search(getFilters(filters), query, this.numberPerPage, this.page)\r\n .then((searchData) => {\r\n this.numberOfHits = searchData.total;\r\n this.discoverIds = searchData.discoverIds;\r\n this._dois = searchData.dois;\r\n this.results = searchData.items;\r\n this.loadingCards = false;\r\n this.scrollToTop();\r\n this.$emit(\"search-changed\", {\r\n value: this.searchInput,\r\n type: \"query-update\",\r\n });\r\n if (this._abortController) this._abortController.abort();\r\n this._abortController = new AbortController();\r\n const signal = this._abortController.signal;\r\n //Search ongoing, let the current flow progress\r\n this.perItemSearch(signal, { count: 0 });\r\n });\r\n },\r\n filtersLoading: function (val) {\r\n this.loadingCards = val;\r\n },\r\n numberPerPageUpdate: function (val) {\r\n this.numberPerPage = val;\r\n this.pageChange(1);\r\n },\r\n pageChange: function (page) {\r\n this.start = (page - 1) * this.numberPerPage;\r\n this.page = page;\r\n this.searchAlgolia(\r\n this.filters,\r\n this.searchInput,\r\n this.numberPerPage,\r\n this.page\r\n );\r\n },\r\n handleMissingData: function (doi) {\r\n let i = this.results.findIndex((res) => res.doi === doi);\r\n if (this.results[i]) this.results[i].detailsReady = true;\r\n },\r\n perItemSearch: function (signal, data) {\r\n //Maximum 10 downloads at once to prevent long waiting time\r\n //between unfinished search and new search\r\n const maxDownloads = 10;\r\n if (maxDownloads > data.count) {\r\n const doi = this._dois.shift();\r\n if (doi) {\r\n data.count++;\r\n this.callSciCrunch(this.envVars.API_LOCATION, { dois: [doi] }, signal)\r\n .then((result) => {\r\n if (result.numberOfHits === 0) this.handleMissingData(doi);\r\n else this.resultsProcessing(result);\r\n this.$refs.content.style[\"overflow-y\"] = \"scroll\";\r\n data.count--;\r\n //Async::Download finished, get the next one\r\n this.perItemSearch(signal, data);\r\n })\r\n .catch((result) => {\r\n if (result.name !== \"AbortError\") {\r\n this.handleMissingData(doi);\r\n data.count--;\r\n //Async::Download not aborted, get the next one\r\n this.perItemSearch(signal, data);\r\n }\r\n });\r\n //Check and make another request until it gets to max downloads\r\n this.perItemSearch(signal, data);\r\n }\r\n }\r\n },\r\n scrollToTop: function () {\r\n if (this.$refs.content) {\r\n this.$refs.content.scroll({ top: 0, behavior: \"smooth\" });\r\n }\r\n },\r\n resetPageNavigation: function () {\r\n this.start = 0;\r\n this.page = 1;\r\n },\r\n resultsProcessing: function (data) {\r\n this.lastSearch = this.searchInput;\r\n\r\n if (data.results.length === 0) {\r\n return;\r\n }\r\n data.results.forEach((element) => {\r\n // match the scicrunch result with algolia result\r\n let i = this.results.findIndex((res) =>\r\n element.doi ? element.doi.includes(res.doi) : false\r\n );\r\n // Assign scicrunch results to the object\r\n Object.assign(this.results[i], element);\r\n // Assign the attributes that need some processing\r\n Object.assign(this.results[i], {\r\n numberSamples: element.sampleSize ? parseInt(element.sampleSize) : 0,\r\n numberSubjects: element.subjectSize\r\n ? parseInt(element.subjectSize)\r\n : 0,\r\n updated:\r\n (element.updated && element.updated.length) > 0\r\n ? element.updated[0].timestamp.split(\"T\")[0]\r\n : \"\",\r\n url: element.uri[0],\r\n datasetId: element.dataset_identifier,\r\n datasetRevision: element.dataset_revision,\r\n datasetVersion: element.dataset_version,\r\n organs:\r\n element.organs && element.organs.length > 0\r\n ? [...new Set(element.organs.map((v) => v.name))]\r\n : undefined,\r\n species: element.organisms\r\n ? element.organisms[0].species\r\n ? [\r\n ...new Set(\r\n element.organisms.map((v) =>\r\n v.species ? v.species.name : null\r\n )\r\n ),\r\n ]\r\n : undefined\r\n : undefined, // This processing only includes each gender once into 'sexes'\r\n scaffolds: element[\"abi-scaffold-metadata-file\"],\r\n thumbnails: element[\"abi-thumbnail\"]\r\n ? element[\"abi-thumbnail\"]\r\n : element[\"abi-scaffold-thumbnail\"],\r\n scaffoldViews: element[\"abi-scaffold-view-file\"],\r\n videos: element.video,\r\n plots: element[\"abi-plot\"],\r\n images: element[\"common-images\"],\r\n contextualInformation:\r\n element[\"abi-contextual-information\"].length > 0\r\n ? element[\"abi-contextual-information\"]\r\n : undefined,\r\n segmentation: element[\"mbf-segmentation\"],\r\n simulation: element[\"abi-simulation-file\"],\r\n additionalLinks: element.additionalLinks,\r\n detailsReady: true,\r\n });\r\n Vue.set(this.results, i, this.results[i]);\r\n });\r\n },\r\n createfilterParams: function (params) {\r\n let p = new URLSearchParams();\r\n //Check if field is array or value\r\n for (const key in params) {\r\n if (Array.isArray(params[key])) {\r\n params[key].forEach((e) => {\r\n p.append(key, e);\r\n });\r\n } else {\r\n p.append(key, params[key]);\r\n }\r\n }\r\n return p.toString();\r\n },\r\n callSciCrunch: function (apiLocation, params = {}, signal) {\r\n return new Promise((resolve, reject) => {\r\n // Add parameters if we are sent them\r\n let fullEndpoint =\r\n this.envVars.API_LOCATION +\r\n this.searchEndpoint +\r\n \"?\" +\r\n this.createfilterParams(params);\r\n fetch(fullEndpoint, { signal })\r\n .then(handleErrors)\r\n .then((response) => response.json())\r\n .then((data) => resolve(data))\r\n .catch((data) => reject(data));\r\n });\r\n },\r\n getAlgoliaFacets: async function(){\r\n let facets = await this.algoliaClient.getAlgoliaFacets(facetPropPathMapping)\r\n return facets;\r\n },\r\n searchHistorySearch: function(item){\r\n this.searchInput = item.search;\r\n this.filters = item.filters;\r\n this.openSearch(item.filters, item.search);\r\n }\r\n },\r\n mounted: function () {\r\n // initialise algolia\r\n this.algoliaClient = new AlgoliaClient(\r\n this.envVars.ALGOLIA_ID,\r\n this.envVars.ALGOLIA_KEY,\r\n this.envVars.PENNSIEVE_API_LOCATION\r\n );\r\n this.algoliaClient.initIndex(this.envVars.ALGOLIA_INDEX);\r\n this.openSearch(this.filter, this.searchInput);\r\n },\r\n created: function () {\r\n //Create non-reactive local variables\r\n this.searchEndpoint = \"dataset_info/using_multiple_dois/\";\r\n },\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/button\";\r\n@import \"~element-ui/packages/theme-chalk/src/card\";\r\n@import \"~element-ui/packages/theme-chalk/src/drawer\";\r\n@import \"~element-ui/packages/theme-chalk/src/icon\";\r\n@import \"~element-ui/packages/theme-chalk/src/input\";\r\n@import \"~element-ui/packages/theme-chalk/src/loading\";\r\n@import \"~element-ui/packages/theme-chalk/src/pagination\";\r\n\r\n.content-card {\r\n height: 100%;\r\n flex-flow: column;\r\n display: flex;\r\n}\r\n\r\n.button {\r\n background-color: $app-primary-color;\r\n border: $app-primary-color;\r\n color: white;\r\n}\r\n\r\n.step-item {\r\n font-size: 14px;\r\n margin-bottom: 18px;\r\n text-align: left;\r\n}\r\n\r\n.search-input {\r\n width: 298px !important;\r\n height: 40px;\r\n padding-right: 14px;\r\n align-items: left;\r\n}\r\n\r\n.header {\r\n border: solid 1px #292b66;\r\n background-color: #292b66;\r\n text-align: left;\r\n}\r\n\r\n.pagination {\r\n padding-bottom: 16px;\r\n background-color: white;\r\n text-align: center;\r\n}\r\n\r\n.pagination ::v-deep button {\r\n background-color: white !important;\r\n}\r\n.pagination ::v-deep li {\r\n background-color: white !important;\r\n}\r\n.pagination ::v-deep li.active {\r\n color: $app-primary-color;\r\n}\r\n\r\n.error-feedback {\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-style: italic;\r\n padding-top: 15px;\r\n}\r\n\r\n.content-card ::v-deep .el-card__header {\r\n background-color: #292b66;\r\n border: solid 1px #292b66;\r\n}\r\n\r\n.content-card ::v-deep .el-card__body {\r\n background-color: #f7faff;\r\n overflow-y: hidden;\r\n}\r\n\r\n.content {\r\n width: 518px;\r\n flex: 1 1 auto;\r\n box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.06);\r\n border: solid 1px #e4e7ed;\r\n background-color: #ffffff;\r\n overflow-y: scroll;\r\n scrollbar-width: thin;\r\n}\r\n\r\n.content ::v-deep .el-loading-spinner .path {\r\n stroke: $app-primary-color;\r\n}\r\n\r\n.content ::v-deep .step-item:first-child .seperator-path {\r\n display: none;\r\n}\r\n\r\n.content ::v-deep .step-item:not(:first-child) .seperator-path {\r\n width: 486px;\r\n height: 0px;\r\n border: solid 1px #e4e7ed;\r\n background-color: #e4e7ed;\r\n}\r\n\r\n.scrollbar::-webkit-scrollbar-track {\r\n border-radius: 10px;\r\n background-color: #f5f5f5;\r\n}\r\n\r\n.scrollbar::-webkit-scrollbar {\r\n width: 12px;\r\n right: -12px;\r\n background-color: #f5f5f5;\r\n}\r\n\r\n.scrollbar::-webkit-scrollbar-thumb {\r\n border-radius: 4px;\r\n box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.06);\r\n background-color: #979797;\r\n}\r\n\r\n::v-deep .el-input__suffix {\r\n padding-right: 10px;\r\n}\r\n\r\n::v-deep .my-drawer {\r\n background: rgba(0, 0, 0, 0);\r\n box-shadow: none;\r\n}\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SidebarContent.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SidebarContent.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SidebarContent.vue?vue&type=template&id=33c92dc7&scoped=true&\"\nimport script from \"./SidebarContent.vue?vue&type=script&lang=js&\"\nexport * from \"./SidebarContent.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SidebarContent.vue?vue&type=style&index=0&id=33c92dc7&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"33c92dc7\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"tab-container\"},_vm._l((_vm.tabTitles),function(title){return _c('div',{key:title.id,staticClass:\"title\"},[_c('div',{staticClass:\"title-text-table\",class:{ highlightText : (title.id==_vm.activeId) },on:{\"click\":function($event){return _vm.titleClicked(title.id)}}},[_c('div',{staticClass:\"title-text\"},[_vm._v(\" \"+_vm._s(title.title)+\" \")])])])}),0)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\r\n <div class=\"tab-container\">\r\n <div class=\"title\" v-for=\"title in tabTitles\" :key=\"title.id\">\r\n <div class=\"title-text-table\" v-bind:class=\"{ highlightText : (title.id==activeId) }\" v-on:click=\"titleClicked(title.id)\">\r\n <div class=\"title-text\">\r\n {{title.title}}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\n\r\nexport default {\r\n name: \"Tabs\",\r\n props: {\r\n tabTitles: {\r\n type: Array,\r\n default: () => []\r\n },\r\n activeId: {\r\n type: Number,\r\n default: 1\r\n }\r\n },\r\n methods: {\r\n titleClicked: function(id) {\r\n this.$emit(\"titleClicked\", id);\r\n },\r\n }\r\n\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n\r\n.tab-container{\r\n height: 28px;\r\n}\r\n\r\n.title {\r\n width: 101px;\r\n height: 28px;\r\n border: solid 1px $lineColor1;\r\n border-bottom: none;\r\n background-color: white;\r\n display:inline-block;\r\n}\r\n\r\n.title:hover {\r\n cursor: pointer;\r\n}\r\n\r\n.title-text {\r\n text-align:center;\r\n display: table-cell;\r\n vertical-align: middle;\r\n font-size: 14px;\r\n}\r\n\r\n.title-text-table {\r\n display:table;\r\n height: 100%;\r\n width: 100%;\r\n}\r\n\r\n.parent-dialog:hover .title-text {\r\n color:$app-primary-color;\r\n}\r\n\r\n.highlightText {\r\n color:$app-primary-color;\r\n}\r\n\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Tabs.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Tabs.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./Tabs.vue?vue&type=template&id=6bfde6c2&scoped=true&\"\nimport script from \"./Tabs.vue?vue&type=script&lang=js&\"\nexport * from \"./Tabs.vue?vue&type=script&lang=js&\"\nimport style0 from \"./Tabs.vue?vue&type=style&index=0&id=6bfde6c2&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"6bfde6c2\",\n null\n \n)\n\nexport default component.exports","<template>\r\n <div ref=\"container\">\r\n <div v-if=\"!drawerOpen\" @click=\"toggleDrawer\" class=\"open-tab\">\r\n <i class=\"el-icon-arrow-left\"></i>\r\n </div>\r\n <el-drawer\r\n custom-class=\"my-drawer\"\r\n class=\"side-bar\"\r\n :visible.sync=\"drawerOpen\"\r\n :appendToBody=\"false\"\r\n :modal-append-to-body=\"false\"\r\n size=550\r\n :with-header=\"false\"\r\n :wrapperClosable=\"false\"\r\n :modal=\"false\"\r\n >\r\n <div class=\"box-card\">\r\n <div v-if=\"drawerOpen\" @click=\"close\" class=\"close-tab\">\r\n <i class=\"el-icon-arrow-right\"></i>\r\n </div>\r\n <div class=\"sidebar-container\">\r\n <tabs v-if=\"tabs.length > 1\" :tabTitles=\"tabs\" :activeId=\"activeId\"\r\n @titleClicked=\"tabClicked\"/>\r\n <template v-for=\"tab in tabs\">\r\n <sidebar-content class=\"sidebar-content-container\"\r\n v-show=\"tab.id===activeId\" :contextCardEntry=\"tab.contextCard\"\r\n :envVars=\"envVars\"\r\n v-bind:key=\"tab.id\" :ref=\"tab.id\"\r\n @search-changed=\"searchChanged(tab.id, $event)\"/>\r\n </template>\r\n </div>\r\n </div>\r\n </el-drawer>\r\n </div>\r\n</template>\r\n\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport {\r\n Drawer,\r\n Icon,\r\n} from \"element-ui\";\r\nimport lang from \"element-ui/lib/locale/lang/en\";\r\nimport locale from \"element-ui/lib/locale\";\r\nimport SidebarContent from './SidebarContent.vue';\r\nimport EventBus from './EventBus';\r\nimport Tabs from './Tabs'\r\n\r\nlocale.use(lang);\r\nVue.use(Drawer);\r\nVue.use(Icon);\r\n\r\nexport default {\r\n components: {SidebarContent, Tabs },\r\n name: \"SideBar\",\r\n props: {\r\n visible: {\r\n type: Boolean,\r\n default: false\r\n },\r\n envVars: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n tabs: {\r\n type: Array,\r\n default: () => [{title:'flatmap', id:1}]\r\n },\r\n activeId: {\r\n type: Number,\r\n default: 1\r\n },\r\n openAtStart: {\r\n type: Boolean,\r\n default: false\r\n }\r\n },\r\n data: function () {\r\n return {\r\n drawerOpen: false,\r\n }\r\n },\r\n methods: {\r\n searchChanged: function (id, data) {\r\n this.$emit(\"search-changed\", {...data, id: id});\r\n },\r\n close: function () {\r\n this.drawerOpen = false;\r\n },\r\n toggleDrawer: function () {\r\n this.drawerOpen = !this.drawerOpen;\r\n },\r\n openSearch: function(facets, query){\r\n this.drawerOpen = true;\r\n // Because refs are in v-for, nextTick is needed here\r\n Vue.nextTick(()=>{this.$refs[this.activeId][0].openSearch(facets, query)})\r\n },\r\n addFilter: function(filter){\r\n this.drawerOpen = true;\r\n filter.AND = true // When we add a filter external, it is currently only with an AND boolean\r\n\r\n // Because refs are in v-for, nextTick is needed here\r\n Vue.nextTick(()=>{this.$refs[this.activeId][0].addFilter(filter)})\r\n },\r\n openNeuronSearch: function(neuron){\r\n this.drawerOpen = true;\r\n // Because refs are in v-for, nextTick is needed here\r\n Vue.nextTick(()=>{this.$refs[this.activeId][0].openSearch('', undefined, 'scicrunch-query-string/', {'field': '*organ.curie', 'curie':neuron})})\r\n },\r\n getAlgoliaFacets: async function(){\r\n return await this.$refs[this.activeId][0].getAlgoliaFacets()\r\n },\r\n setDrawerOpen: function(value=true){\r\n this.drawerOpen = value;\r\n },\r\n tabClicked: function(id) {\r\n this.$emit(\"tabClicked\", id);\r\n },\r\n },\r\n created:function() {\r\n this.drawerOpen = this.openAtStart;\r\n },\r\n mounted: function(){\r\n EventBus.$on(\"PopoverActionClick\", (payLoad) => {\r\n this.$emit(\"actionClick\", payLoad);\r\n })\r\n EventBus.$on('available-facets', (payLoad)=> {\r\n this.$emit('search-changed', {\r\n type: 'available-facets',\r\n value: payLoad\r\n })\r\n })\r\n EventBus.$on('contextUpdate', (payLoad)=> {\r\n this.$emit('contextUpdate', payLoad)\r\n })\r\n }\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/drawer\";\r\n@import \"~element-ui/packages/theme-chalk/src/icon\";\r\n\r\n.box-card {\r\n flex: 3;\r\n height: 100%;\r\n overflow: hidden;\r\n pointer-events: auto;\r\n}\r\n\r\n.side-bar{\r\n position: relative;\r\n height: 100%;\r\n pointer-events: none;\r\n}\r\n\r\n.side-bar ::v-deep .el-drawer:focus{\r\n outline:none;\r\n}\r\n\r\n.sidebar-container {\r\n height: 100%;\r\n flex-flow: column;\r\n display: flex;\r\n}\r\n\r\n.open-tab{\r\n width: 20px;\r\n height: 40px;\r\n z-index: 8;\r\n position: absolute;\r\n top: calc(50vh - 80px);\r\n right: 0px;\r\n box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.06);\r\n border: solid 1px $app-primary-color;\r\n background-color: #f9f2fc;\r\n text-align: center;\r\n vertical-align: middle;\r\n cursor: pointer;\r\n pointer-events: auto;\r\n}\r\n\r\n.el-icon-arrow-left,\r\n.el-icon-arrow-right\r\n{\r\n font-weight: 600;\r\n margin-top: 12px;\r\n color: $app-primary-color;\r\n cursor: pointer;\r\n pointer-events: auto;\r\n transform: scaleY(2.0);\r\n text-align: center;\r\n vertical-align: middle;\r\n}\r\n\r\n.close-tab{\r\n float: left;\r\n flex: 1;\r\n width: 20px;\r\n height: 40px;\r\n z-index: 8;\r\n margin-top: calc(50vh - 80px);\r\n box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.06);\r\n border: solid 1px $app-primary-color; \r\n background-color: #f9f2fc;\r\n text-align: center;\r\n vertical-align: middle;\r\n cursor: pointer;\r\n pointer-events: auto;\r\n}\r\n\r\n.box-card {\r\n flex: 3;\r\n height: 100%;\r\n overflow: hidden;\r\n pointer-events: auto;\r\n}\r\n\r\n::v-deep .my-drawer {\r\n background: rgba(0,0,0,0);\r\n box-shadow: none;\r\n}\r\n\r\n::v-deep .my-drawer .el-drawer__body {\r\n height: 100%;\r\n}\r\n\r\n.sidebar-content-container {\r\n flex: 1 1 auto;\r\n}\r\n\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SideBar.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SideBar.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SideBar.vue?vue&type=template&id=11bc3f45&scoped=true&\"\nimport script from \"./SideBar.vue?vue&type=script&lang=js&\"\nexport * from \"./SideBar.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SideBar.vue?vue&type=style&index=0&id=11bc3f45&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"11bc3f45\",\n null\n \n)\n\nexport default component.exports","import SideBar from \"./SideBar.vue\"\r\n\r\nexport {\r\n SideBar\r\n};\r\n\r\n\r\n\r\n","import './setPublicPath'\nexport * from '~entry'\n","module.exports = require(\"core-js/modules/es.string.includes\");","module.exports = require(\"core-js/modules/es.array.find\");"],"sourceRoot":""}
|
|
1
|
+
{"version":3,"sources":["webpack://map-side-bar/webpack/bootstrap","webpack://map-side-bar/external \"element-ui/lib/pagination\"","webpack://map-side-bar/external \"core-js/modules/es.symbol.iterator\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/pagination.css\"","webpack://map-side-bar/external \"@abi-software/gallery/src/main-bundle.js\"","webpack://map-side-bar/./src/components/SearchHistory.vue?c814","webpack://map-side-bar/external \"core-js/modules/es.parse-int\"","webpack://map-side-bar/external \"element-ui/lib/select\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/select.css\"","webpack://map-side-bar/external \"core-js/modules/es.array.for-each\"","webpack://map-side-bar/./src/components/SidebarContent.vue?56f4","webpack://map-side-bar/external \"core-js/modules/es.array.concat\"","webpack://map-side-bar/external \"core-js/modules/web.dom-collections.iterator\"","webpack://map-side-bar/external \"core-js/modules/es.object.keys\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/button.css\"","webpack://map-side-bar/external \"core-js/modules/web.url\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/loading.css\"","webpack://map-side-bar/./src/components/ImageGallery.vue?bd5b","webpack://map-side-bar/./src/components/DatasetCard.vue?40b1","webpack://map-side-bar/external \"element-ui/lib/drawer\"","webpack://map-side-bar/./src/components/ImageGallery.vue?140b","webpack://map-side-bar/external \"core-js/modules/es.string.trim\"","webpack://map-side-bar/external \"core-js/modules/es.array.join\"","webpack://map-side-bar/./src/components/SearchFilters.vue?ccce","webpack://map-side-bar/external \"@abi-software/svg-sprite\"","webpack://map-side-bar/external \"core-js/modules/es.object.get-own-property-descriptors\"","webpack://map-side-bar/external \"core-js/modules/es.string.split\"","webpack://map-side-bar/external \"core-js/modules/es.set\"","webpack://map-side-bar/external \"core-js/modules/es.array.filter\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/card.css\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/drawer.css\"","webpack://map-side-bar/./src/components/SearchFilters.vue?1ef4","webpack://map-side-bar/external \"core-js/modules/es.symbol.description\"","webpack://map-side-bar/external \"core-js/modules/es.regexp.exec\"","webpack://map-side-bar/external \"element-ui/lib/button\"","webpack://map-side-bar/external \"core-js/modules/es.regexp.to-string\"","webpack://map-side-bar/external \"core-js/modules/es.symbol\"","webpack://map-side-bar/external \"core-js/modules/es.array.slice\"","webpack://map-side-bar/external \"core-js/modules/es.object.get-own-property-descriptor\"","webpack://map-side-bar/external \"element-ui/lib/cascader\"","webpack://map-side-bar/./src/components/DatasetCard.vue?59a6","webpack://map-side-bar/external \"element-ui/lib/locale/lang/en\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/cascader.css\"","webpack://map-side-bar/external \"core-js/modules/es.array.sort\"","webpack://map-side-bar/external \"core-js/modules/es.number.constructor\"","webpack://map-side-bar/external \"regenerator-runtime/runtime\"","webpack://map-side-bar/external \"core-js/modules/es.array.splice\"","webpack://map-side-bar/external \"element-ui/lib/locale\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/option.css\"","webpack://map-side-bar/external \"core-js/modules/es.promise\"","webpack://map-side-bar/external \"core-js/modules/es.object.to-string\"","webpack://map-side-bar/external \"algoliasearch\"","webpack://map-side-bar/external \"vue\"","webpack://map-side-bar/external \"core-js/modules/es.array.iterator\"","webpack://map-side-bar/./src/components/SearchHistory.vue?4296","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/icon.css\"","webpack://map-side-bar/./src/components/Tabs.vue?3e70","webpack://map-side-bar/external \"core-js/modules/es.string.iterator\"","webpack://map-side-bar/./src/components/SearchHistory.vue?2a80","webpack://map-side-bar/external \"element-ui/lib/popover\"","webpack://map-side-bar/external \"core-js/modules/es.map\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/base.css\"","webpack://map-side-bar/external \"core-js/modules/es.array.flat\"","webpack://map-side-bar/./assets/missing-image.svg","webpack://map-side-bar/external \"@abi-software/gallery/src/mixins/GalleryHelpers\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/popover.css\"","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/input.css\"","webpack://map-side-bar/external \"core-js/modules/es.array.includes\"","webpack://map-side-bar/external \"element-ui/lib/loading\"","webpack://map-side-bar/external \"core-js/modules/es.array.find-index\"","webpack://map-side-bar/external \"element-ui/lib/tag\"","webpack://map-side-bar/./src/components/BadgesGroup.vue?b201","webpack://map-side-bar/external \"element-ui/lib/card\"","webpack://map-side-bar/external \"element-ui/lib/icon\"","webpack://map-side-bar/external \"core-js/modules/es.object.assign\"","webpack://map-side-bar/./src/components/SideBar.vue?4c29","webpack://map-side-bar/external \"core-js/modules/es.function.name\"","webpack://map-side-bar/external \"core-js/modules/web.dom-collections.for-each\"","webpack://map-side-bar/external \"core-js/modules/es.string.search\"","webpack://map-side-bar/external \"core-js/modules/es.string.replace\"","webpack://map-side-bar/external \"element-ui/lib/option\"","webpack://map-side-bar/./src/components/Tabs.vue?8d2a","webpack://map-side-bar/./src/components/BadgesGroup.vue?1918","webpack://map-side-bar/./src/components/SearchHistory.vue?4bed","webpack://map-side-bar/./src/components/SideBar.vue?0b7f","webpack://map-side-bar/external \"element-ui/lib/theme-chalk/tag.css\"","webpack://map-side-bar/external \"core-js/modules/es.array.last-index-of\"","webpack://map-side-bar/external \"current-script-polyfill\"","webpack://map-side-bar/external \"core-js/modules/es.array.from\"","webpack://map-side-bar/external \"element-ui/lib/input\"","webpack://map-side-bar/./src/components/SidebarContent.vue?a5ca","webpack://map-side-bar/external \"core-js/modules/es.object.entries\"","webpack://map-side-bar/external \"core-js/modules/es.array.unscopables.flat\"","webpack://map-side-bar/external \"core-js/modules/es.array.map\"","webpack://map-side-bar/external \"core-js/modules/es.promise.finally\"","webpack://map-side-bar/./node_modules/@vue/cli-service/lib/commands/build/setPublicPath.js","webpack://map-side-bar/./src/components/SideBar.vue?2b06","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/defineProperty.js","webpack://map-side-bar/./src/components/SidebarContent.vue?b752","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/iterableToArray.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","webpack://map-side-bar/./src/components/SearchFilters.vue?1fa8","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/toArray.js","webpack://map-side-bar/src/components/Cascader.vue","webpack://map-side-bar/./src/components/Cascader.vue?9729","webpack://map-side-bar/./node_modules/vue-loader/lib/runtime/componentNormalizer.js","webpack://map-side-bar/./src/components/Cascader.vue","webpack://map-side-bar/./src/components/species-map.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/classCallCheck.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/createClass.js","webpack://map-side-bar/./src/algolia/algolia.js","webpack://map-side-bar/./src/algolia/utils.js","webpack://map-side-bar/src/components/SearchFilters.vue","webpack://map-side-bar/./src/components/SearchFilters.vue?8079","webpack://map-side-bar/./src/components/SearchFilters.vue","webpack://map-side-bar/./src/components/SearchHistory.vue?fc31","webpack://map-side-bar/./src/components/EventBus.js","webpack://map-side-bar/src/components/SearchHistory.vue","webpack://map-side-bar/./src/components/SearchHistory.vue?c6dc","webpack://map-side-bar/./src/components/SearchHistory.vue","webpack://map-side-bar/./src/components/DatasetCard.vue?e0ad","webpack://map-side-bar/./src/components/BadgesGroup.vue?23a5","webpack://map-side-bar/src/components/BadgesGroup.vue","webpack://map-side-bar/./src/components/BadgesGroup.vue?6a7e","webpack://map-side-bar/./src/components/BadgesGroup.vue","webpack://map-side-bar/./src/components/ImageGallery.vue?c32c","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","webpack://map-side-bar/./node_modules/@babel/runtime/helpers/esm/slicedToArray.js","webpack://map-side-bar/src/mixins/S3Bucket.vue","webpack://map-side-bar/./src/mixins/S3Bucket.vue?faba","webpack://map-side-bar/./src/mixins/S3Bucket.vue","webpack://map-side-bar/src/components/ImageGallery.vue","webpack://map-side-bar/./src/components/ImageGallery.vue?b8b4","webpack://map-side-bar/./src/components/ImageGallery.vue","webpack://map-side-bar/src/components/DatasetCard.vue","webpack://map-side-bar/./src/components/DatasetCard.vue?d021","webpack://map-side-bar/./src/components/DatasetCard.vue","webpack://map-side-bar/src/components/SidebarContent.vue","webpack://map-side-bar/./src/components/SidebarContent.vue?7e01","webpack://map-side-bar/./src/components/SidebarContent.vue","webpack://map-side-bar/./src/components/Tabs.vue?1923","webpack://map-side-bar/src/components/Tabs.vue","webpack://map-side-bar/./src/components/Tabs.vue?3d38","webpack://map-side-bar/./src/components/Tabs.vue","webpack://map-side-bar/src/components/SideBar.vue","webpack://map-side-bar/./src/components/SideBar.vue?b259","webpack://map-side-bar/./src/components/SideBar.vue","webpack://map-side-bar/./src/components/index.js","webpack://map-side-bar/./node_modules/@vue/cli-service/lib/commands/build/entry-lib-no-default.js","webpack://map-side-bar/external \"core-js/modules/es.string.includes\"","webpack://map-side-bar/external \"core-js/modules/es.array.find\""],"names":["asyncGeneratorStep","gen","resolve","reject","_next","_throw","key","arg","info","value","error","done","Promise","then","_asyncToGenerator","fn","self","args","arguments","apply","err","undefined","_defineProperty","obj","Object","defineProperty","enumerable","configurable","writable","_arrayWithoutHoles","arr","Array","isArray","i","arr2","length","_iterableToArray","iter","Symbol","iterator","prototype","toString","call","from","_nonIterableSpread","TypeError","_toConsumableArray","arrayWithoutHoles","iterableToArray","nonIterableSpread","_arrayWithHoles","_nonIterableRest","_toArray","arrayWithHoles","nonIterableRest","_classCallCheck","instance","Constructor","_defineProperties","target","props","descriptor","_createClass","protoProps","staticProps","AlgoliaClient","algoliaId","algoliaKey","PENNSIEVE_API_LOCATION","client","algoliasearch","anatomyFacetLabels","ALGOLIA_INDEX","index","initIndex","propPathMapping","map","Map","entries","facetPropPaths","keys","facetData","facetId","search","sortFacetValuesBy","facets","response","facetPropPath","children","responseFacets","responseFacetChildren","facet","push","label","id","get","discoverId","fetch","r","json","dataset","version","doi","discoverIds","promiseList","_discoverAllDois","all","values","flat","results","newResults","newResult","res","item","curie","split","name","description","updated","pennsieve","updatedAt","publishDate","datasetId","objectID","detailsReady","hits","foundKeyWords","foundLabels","uniqueLabels","uniqueKeywords","forEach","hit","keywords","keywordObj","keyword","toUpperCase","includes","_processUberonURL","anatomy","organ","Set","url","ub","pop","replace","filter","query","hitsperPage","page","hitsPerPage","filters","attributesToHighlight","attributesToRetrieve","searchData","items","_processResultsForCards","total","nbHits","identifier","dois","anatomyAsUberons","_processAnatomy","facetPropPathMapping","shownFilters","getFilters","selectedFacetArray","f","removeShowAllFacets","facetsToBool","orFilters","andFilters","AND","substring","lastIndexOf","join","facetArray","EventBus","Vue","_iterableToArrayLimit","_arr","_n","_d","_e","_i","_s","next","_slicedToArray","iterableToArrayLimit"],"mappings":";;QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;AClFA,sD;;;;;;;ACAA,+D;;;;;;;ACAA,sE;;;;;;;ACAA,qE;;;;;;;;ACAA;AAAA;AAAA;AAAgiB,CAAgB,qkBAAG,EAAC,C;;;;;;;ACApjB,yD;;;;;;;ACAA,kD;;;;;;;ACAA,kE;;;;;;;ACAA,8D;;;;;;;;ACAA;AAAA;AAAA;AAAyjB,CAAgB,8lBAAG,EAAC,C;;;;;;;ACA7kB,4D;;;;;;;ACAA,yE;;;;;;;ACAA,2D;;;;;;;ACAA,kE;;;;;;;ACAA,oD;;;;;;;ACAA,mE;;;;;;;ACAA,uC;;;;;;;ACAA,uC;;;;;;;ACAA,kD;;;;;;;;ACAA;AAAA;AAAA;AAAujB,CAAgB,4lBAAG,EAAC,C;;;;;;;ACA3kB,2D;;;;;;;ACAA,0D;;;;;;;;ACAA;AAAA;AAAA;AAAwjB,CAAgB,6lBAAG,EAAC,C;;;;;;;ACA5kB,qD;;;;;;;ACAA,mF;;;;;;;ACAA,4D;;;;;;;ACAA,mD;;;;;;;ACAA,4D;;;;;;;ACAA,gE;;;;;;;ACAA,kE;;;;;;;ACAA,uC;;;;;;;ACAA,kE;;;;;;;ACAA,2D;;;;;;;ACAA,kD;;;;;;;ACAA,gE;;;;;;;ACAA,sD;;;;;;;ACAA,2D;;;;;;;ACAA,kF;;;;;;;ACAA,oD;;;;;;;;ACAA;AAAA;AAAA;AAAsjB,CAAgB,2lBAAG,EAAC,C;;;;;;;ACA1kB,0D;;;;;;;ACAA,oE;;;;;;;ACAA,0D;;;;;;;ACAA,kE;;;;;;;ACAA,wD;;;;;;;ACAA,4D;;;;;;;ACAA,kD;;;;;;;ACAA,kE;;;;;;;ACAA,uD;;;;;;;ACAA,gE;;;;;;;ACAA,0C;;;;;;;ACAA,gC;;;;;;;ACAA,8D;;;;;;;;ACAA;AAAA;AAAA;AAAwjB,CAAgB,6lBAAG,EAAC,C;;;;;;;ACA5kB,gE;;;;;;;;ACAA;AAAA;AAAA;AAA+iB,CAAgB,olBAAG,EAAC,C;;;;;;;ACAnkB,+D;;;;;;;ACAA,uC;;;;;;;ACAA,mD;;;;;;;ACAA,mD;;;;;;;ACAA,gE;;;;;;;ACAA,0D;;;;;;;ACAA,iBAAiB,qBAAuB,oC;;;;;;;ACAxC,4E;;;;;;;ACAA,mE;;;;;;;ACAA,iE;;;;;;;ACAA,8D;;;;;;;ACAA,mD;;;;;;;ACAA,gE;;;;;;;ACAA,+C;;;;;;;ACAA,uC;;;;;;;ACAA,gD;;;;;;;ACAA,gD;;;;;;;ACAA,6D;;;;;;;;ACAA;AAAA;AAAA;AAAkjB,CAAgB,ulBAAG,EAAC,C;;;;;;;ACAtkB,6D;;;;;;;ACAA,yE;;;;;;;ACAA,6D;;;;;;;ACAA,8D;;;;;;;ACAA,kD;;;;;;;ACAA,uC;;;;;;;;ACAA;AAAA;AAAA;AAAsjB,CAAgB,2lBAAG,EAAC,C;;;;;;;ACA1kB,uC;;;;;;;ACAA,uC;;;;;;;ACAA,+D;;;;;;;ACAA,mE;;;;;;;ACAA,oD;;;;;;;ACAA,0D;;;;;;;ACAA,iD;;;;;;;ACAA,uC;;;;;;;ACAA,8D;;;;;;;ACAA,sE;;;;;;;ACAA,yD;;;;;;;ACAA,+D;;;;;;;;;;;;;;;ACAA;;AAEA;AACA,MAAM,IAAuC;AAC7C,IAAI,mBAAO,CAAC,MAAyB;AACrC;;AAEA,MAAM,eAAC;AACP,OAAO,eAAC,sCAAsC,eAAC,GAAG,eAAC;AACnD,IAAI,qBAAuB,GAAG,eAAC;AAC/B;AACA;;AAEA;AACe,sDAAI;;;ACdnB,0BAA0B,aAAa,0BAA0B,wBAAwB,iBAAiB,gBAAgB,8BAA8B,2BAA2B,0BAA0B,UA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gBAAe,CAAClB,GAAD,CAAtC,IAA+CwB,gBAAe,EAArE;AACD,C;;;;;;;;;;;;;;;;;;;;ACJD;AAGA;AACA,wBADA;AAEA,6BAFA;AAGA;AACA;AACA,sBAFA,gCAEA;AAAA,UACA,UADA,GACA,IADA,CACA,UADA;AAAA,UACA,QADA,GACA,IADA,CACA,QADA;AAAA,UACA,aADA,GACA,IADA,CACA,aADA;AAAA,UACA,SADA,GACA,IADA,CACA,SADA;AAAA,UACA,YADA,GACA,IADA,CACA,YADA;AAEA;AACA;;AACA;AAAA;AACA,oBADA;AAEA,uBAFA;AAGA,sDAHA;AAIA,yBAJA;AAKA;AALA;AAAA;;AAOA,4DACA;AACA;AACA,OAHA;;AAKA;AAAA,oCACA,WADA;AAAA,YACA,KADA;AAAA,YACA,IADA;;AAEA;AACA;;AACA;AACA;AACA;AACA,qBADA;AAEA,0CAFA;AAGA;AAHA;AAKA,WANA,MAMA;AACA;AAAA;AAAA;AACA;AACA;AACA;;AACA;AACA;AACA;AACA;AArCA;AAHA,G;;ACJkU,CAAgB,gHAAG,EAAC,C;;ACAtV;;AAEA;AACA;AACA;;AAEe;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,yBAAyB;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,qBAAqB;AACrB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;;AC5FA,IAAI,eAAM,EAAE,wBAAe;AACiC;AACL;;;AAGvD;AAC0F;AAC1F,gBAAgB,kBAAU;AAC1B,EAAE,2CAAM;AACR,EAAE,eAAM;AACR,EA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KAzCA;AA0CA;AACA;AACA;AACA,OAFA,MAEA;AACA;AACA;AACA,KAhDA;AAiDA;AACA;AACA;AACA;AACA,iDAFA,CAIA;;AACA;AAAA;AAAA;AAAA;AACA,gCADA;AAEA,sCAFA;AAGA,qCAHA;AAIA,sBAJA,CAIA;;AAJA;AAAA,WALA,CAYA;;AACA;AAAA;AAAA;AACA;AACA;AACA,mCADA;AAEA,sCAFA;AAGA,qCAHA;AAIA,sBAJA,CAIA;;AAJA;AAMA,SARA;AAWA,oCAxBA,CAwBA;;AAEA,6CA1BA,CA0BA;;AACA,qCA3BA,CA2BA;;AACA;AACA;AACA,KAjFA;AAkFA;AACA;AACA;AAAA;;AACA;AACA,6BACA,GADA,CACA;AAAA;AAAA,OADA,EAEA,QAFA,CAEA,IAFA,EAFA,CAKA;;AACA;AACA;AACA,2BAFA,CAGA;;AACA;AACA;AACA;AACA,SAPA,CAQA;;;AACA;AACA,kCADA,CAEA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA;AACA;AACA;AACA;AACA,+CACA,8EADA,KAEA;AACA,aANA,MAMA;AACA;AACA;AACA;AACA,WAXA,MAWA;AACA;AACA;AACA,SAjCA,CAkCA;;;AACA;AACA;AACA;AACA;AACA;AACA,eAFA,MAEA;AACA;AACA;AACA,aANA,MAMA;AACA;AACA;AACA,eAFA,MAEA;AACA;AACA;AACA,aANA,MAMA;AACA;AACA;AACA,WAhBA,MAgBA;AACA,SAlBA;AAmBA;;AACA;AACA,KAlJA;AAmJA;AACA;AACA;AACA;AACA,KAvJA;AAwJA;AACA;AACA,KA1JA;AA2JA;AAAA;;AACA;AACA;AACA;AACA;;AACA;AACA,2DACA;AACA,OAHA;AAIA,KApKA;AAqKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;;AACA;AACA;AACA;AACA,kBACA,eADA,EAEA,2DAFA;AAIA,SALA,EADA,CAQA;AACA;;AACA;AACA,kBACA,eADA,EAEA,2DAFA,EAGA,KAHA;AAKA,SANA;AAOA;AACA;AACA,KAlMA;AAmMA;AACA;AACA;AACA;AACA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;;;;;;;;;;;;;;;;ACsBxB;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA,qBADA;AAEA;AAAA;AAAA;AAAA,GAFA;AAGA;AACA;;;;AAIA;AACA,kBADA;AAEA;AAFA,KALA;AASA;AACA,kBADA;AAEA;AAFA;AATA,GAHA;AAiBA;AACA;AACA,4CADA;AAEA,kCAFA;AAGA,2BAHA;AAIA,mBAJA;AAKA,gBALA;AAMA,wBANA;AAOA,8BAPA;AAQA;AARA;AAUA,GA5BA;AA6BA;AACA;AACA;;AACA;AACA;AACA;AACA,SAFA,MAEA;AACA;AACA,SAFA,MAEA;AACA;AACA;AACA;;AACA;AACA,KAbA;AAcA;AACA;;AACA;AACA;AACA;AACA,SAFA,MAEA;AACA;AACA;AACA;;AACA;AACA;;AACA;AACA;AACA,SAFA,MAEA;AACA;AACA;;AACA;AACA;AACA,SAFA,MAEA;AACA;AACA;;AACA;AACA;;AAEA;AACA,KAvCA;AAwCA;AACA;AACA,KA1CA;AA2CA;AACA;AACA;AA7CA,GA7BA;AA4EA;AACA;AACA;AACA,KAHA;AAIA;AACA;AACA,KANA;AAOA;AACA;AACA,KATA;AAUA;AACA;AACA,KAZA;AAaA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA;AACA;AACA;;AACA;AACA;AACA;;AACA;AACA;AACA;;AACA;AACA;AACA,WAXA;;AAYA;AAAA;AAAA;AACA;AACA,OAnBA;AAoBA,KAnCA;AAoCA;AACA;AACA,yDAFA,CAEA;AACA,KAvCA;AAwCA;AACA;AACA,KA1CA;AA2CA;AAAA;;AACA;AACA;AACA;AACA;AACA;AACA,4HACA,IADA,CACA;AACA;AACA;AACA,WAFA,MAEA;AACA;AACA;AACA,SAPA,EAQA,IARA,CAQA;AACA;AACA;AACA;AACA;;AACA;;AACA;AACA,SAfA,EAgBA,KAhBA,CAgBA;AACA;AACA;AACA;AACA;AACA,SArBA;AAsBA;AAEA,KAzEA;AA0EA;AACA;AACA,KA5EA;AA6EA;AAAA;;AACA;AACA,wDAFA,CAGA;;AACA,sBACA,IADA,CACA;AAAA;AAAA,OADA,EAEA,IAFA,CAEA;AACA,sCACA;AACA,OALA;AAMA;AAvFA,GA5EA;AAqKA;AACA;AACA,GAvKA;AAwKA;AACA;AACA;AAAA;AACA;AACA;AAJA;AAxKA,G;;ACvDqU,CAAgB,sHAAG,EAAC,C;;;;;ACAnP;AACvC;AACL;AACsC;;;AAGhG;AAC0F;AAC1F,IAAI,qBAAS,GAAG,kBAAU;AAC1B,EAAE,8CAAM;AACR,EAAE,2DAAM;AACR,EAAE,oEAAe;AACjB;AACA;AACA;AACA;;AAEA;;AAEe,qEAAS,Q;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC+BxB;AACA;AAUA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iD,CAEA;AACA;;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gBACA,WADA;AAAA;AAAA;AAAA;;AAAA;AAAA,mBAEA,eAFA;;AAAA;AAEA,iBAFA;;AAAA,iBAGA,KAHA;AAAA;AAAA;AAAA;;AAAA,kBAIA,wBAJA;;AAAA;AAAA,kBAMA,mBANA;;AAAA;AAAA,6CASA,QATA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;;AAYA;AACA,iBADA;AAEA,gBAFA;AAGA,aAHA;AAIA,iBAJA;AAKA,YALA;AAMA,qBANA;AAOA,mBAPA;AAQA,SARA;AASA,cATA;AAUA,UAVA;AAWA,oBAXA;AAYA;AAZA;AAeA;AACA;AAAA;AAAA;AAAA;AAAA,GADA;AAEA,wBAFA;AAGA;AACA;AACA,mBADA;AAEA;AAFA,KADA;AAKA;AACA,mBADA;AAEA;AAFA,KALA;AASA;AACA,kBADA;AAEA;AAAA;AAAA;AAFA,KATA;AAaA;AACA,kBADA;AAEA;AAFA;AAbA,GAHA;AAqBA;AACA,WAAW,uDACX,UADA;AAEA;AACA,wBADA;AAEA,6BAFA;AAGA;AAHA,OAFA;AAOA;AAPA;AASA,GA/BA;AAgCA;AACA;AACA;AACA;AACA,uCADA;AAEA;AAFA;AAIA;AAPA,GAhCA;AAyCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAPA;AAQA;AAAA;AACA;AACA,iCAFA,CAGA;;AACA;AACA,wEADA,CAEA;AACA;AACA;;AACA,YACA,UACA,iBADA,IAEA,WAFA,IAGA,wBAJA,EAKA;AACA;AACA;AACA,SARA,MAQA;AACA;AACA;AACA;AACA,OAjBA,MAiBA;AACA;AACA;AACA;;AACA;AACA;AACA;AACA;AACA,KArCA;AAsCA;AACA;AACA;;AACA;AACA,uDACA;AACA;AACA,OANA,MAMA;AACA;AACA;AACA,SAFA,MAEA;AACA;AACA;AACA;AACA,KApDA;AAqDA;AACA;AACA;AACA,KAxDA;AAyDA;AACA;AACA;AACA;AACA;AACA,KA9DA;AA+DA;AAAA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAtEA;AAuEA;AACA;AACA;AACA;AACA;AACA,sBADA;AAEA;AAFA;AAIA,KA/EA;AAgFA,iBAhFA,yBAgFA,OAhFA,EAgFA;AAAA;;AAAA;AACA;AACA;AACA,yBACA,eADA,CACA,mBADA,EACA,KADA,EAEA,IAFA,CAEA;AACA;AACA,4BADA;AAEA;AAFA;AAIA,OAPA;AAQA,yBACA,MADA,CACA,mBADA,EACA,KADA,EACA,kBADA,EACA,SADA,EAEA,IAFA,CAEA;AACA;AACA;AACA;AACA;AACA;;AACA;;AACA;AACA,kCADA;AAEA;AAFA;;AAIA;AACA;AACA,mDAbA,CAcA;;AACA;AAAA;AAAA;AACA,OAlBA;AAmBA,KA9GA;AA+GA;AACA;AACA,KAjHA;AAkHA;AACA;AACA;AACA,KArHA;AAsHA;AACA;AACA;AACA,yBACA,YADA,EAEA,gBAFA,EAGA,kBAHA,EAIA,SAJA;AAMA,KA/HA;AAgIA;AACA;AAAA;AAAA;AACA;AACA,KAnIA;AAoIA;AAAA;;AACA;AACA;AACA;;AACA;AACA;;AACA;AACA;AACA;AAAA;AAAA,qBA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","file":"map-side-bar.common.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"fae3\");\n","module.exports = require(\"element-ui/lib/pagination\");","module.exports = require(\"core-js/modules/es.symbol.iterator\");","module.exports = require(\"element-ui/lib/theme-chalk/pagination.css\");","module.exports = require(\"@abi-software/gallery/src/main-bundle.js\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=style&index=1&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=style&index=1&lang=scss&\"","module.exports = require(\"core-js/modules/es.parse-int\");","module.exports = require(\"element-ui/lib/select\");","module.exports = require(\"element-ui/lib/theme-chalk/select.css\");","module.exports = require(\"core-js/modules/es.array.for-each\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SidebarContent.vue?vue&type=style&index=0&id=33c92dc7&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SidebarContent.vue?vue&type=style&index=0&id=33c92dc7&scoped=true&lang=scss&\"","module.exports = require(\"core-js/modules/es.array.concat\");","module.exports = require(\"core-js/modules/web.dom-collections.iterator\");","module.exports = require(\"core-js/modules/es.object.keys\");","module.exports = require(\"element-ui/lib/theme-chalk/button.css\");","module.exports = require(\"core-js/modules/web.url\");","module.exports = require(\"element-ui/lib/theme-chalk/loading.css\");","// extracted by mini-css-extract-plugin","// extracted by mini-css-extract-plugin","module.exports = require(\"element-ui/lib/drawer\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ImageGallery.vue?vue&type=style&index=0&id=31f0d189&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ImageGallery.vue?vue&type=style&index=0&id=31f0d189&scoped=true&lang=scss&\"","module.exports = require(\"core-js/modules/es.string.trim\");","module.exports = require(\"core-js/modules/es.array.join\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchFilters.vue?vue&type=style&index=0&id=228b9f2c&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchFilters.vue?vue&type=style&index=0&id=228b9f2c&scoped=true&lang=scss&\"","module.exports = require(\"@abi-software/svg-sprite\");","module.exports = require(\"core-js/modules/es.object.get-own-property-descriptors\");","module.exports = require(\"core-js/modules/es.string.split\");","module.exports = require(\"core-js/modules/es.set\");","module.exports = require(\"core-js/modules/es.array.filter\");","module.exports = require(\"element-ui/lib/theme-chalk/card.css\");","module.exports = require(\"element-ui/lib/theme-chalk/drawer.css\");","// extracted by mini-css-extract-plugin","module.exports = require(\"core-js/modules/es.symbol.description\");","module.exports = require(\"core-js/modules/es.regexp.exec\");","module.exports = require(\"element-ui/lib/button\");","module.exports = require(\"core-js/modules/es.regexp.to-string\");","module.exports = require(\"core-js/modules/es.symbol\");","module.exports = require(\"core-js/modules/es.array.slice\");","module.exports = require(\"core-js/modules/es.object.get-own-property-descriptor\");","module.exports = require(\"element-ui/lib/cascader\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./DatasetCard.vue?vue&type=style&index=0&id=b08ebd76&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./DatasetCard.vue?vue&type=style&index=0&id=b08ebd76&scoped=true&lang=scss&\"","module.exports = require(\"element-ui/lib/locale/lang/en\");","module.exports = require(\"element-ui/lib/theme-chalk/cascader.css\");","module.exports = require(\"core-js/modules/es.array.sort\");","module.exports = require(\"core-js/modules/es.number.constructor\");","module.exports = require(\"regenerator-runtime/runtime\");","module.exports = require(\"core-js/modules/es.array.splice\");","module.exports = require(\"element-ui/lib/locale\");","module.exports = require(\"element-ui/lib/theme-chalk/option.css\");","module.exports = require(\"core-js/modules/es.promise\");","module.exports = require(\"core-js/modules/es.object.to-string\");","module.exports = require(\"algoliasearch\");","module.exports = require(\"vue\");","module.exports = require(\"core-js/modules/es.array.iterator\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=style&index=0&id=84745c26&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=style&index=0&id=84745c26&scoped=true&lang=scss&\"","module.exports = require(\"element-ui/lib/theme-chalk/icon.css\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Tabs.vue?vue&type=style&index=0&id=6bfde6c2&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Tabs.vue?vue&type=style&index=0&id=6bfde6c2&scoped=true&lang=scss&\"","module.exports = require(\"core-js/modules/es.string.iterator\");","// extracted by mini-css-extract-plugin","module.exports = require(\"element-ui/lib/popover\");","module.exports = require(\"core-js/modules/es.map\");","module.exports = require(\"element-ui/lib/theme-chalk/base.css\");","module.exports = require(\"core-js/modules/es.array.flat\");","module.exports = __webpack_public_path__ + \"img/missing-image.1878d8b8.svg\";","module.exports = require(\"@abi-software/gallery/src/mixins/GalleryHelpers\");","module.exports = require(\"element-ui/lib/theme-chalk/popover.css\");","module.exports = require(\"element-ui/lib/theme-chalk/input.css\");","module.exports = require(\"core-js/modules/es.array.includes\");","module.exports = require(\"element-ui/lib/loading\");","module.exports = require(\"core-js/modules/es.array.find-index\");","module.exports = require(\"element-ui/lib/tag\");","// extracted by mini-css-extract-plugin","module.exports = require(\"element-ui/lib/card\");","module.exports = require(\"element-ui/lib/icon\");","module.exports = require(\"core-js/modules/es.object.assign\");","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SideBar.vue?vue&type=style&index=0&id=11bc3f45&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SideBar.vue?vue&type=style&index=0&id=11bc3f45&scoped=true&lang=scss&\"","module.exports = require(\"core-js/modules/es.function.name\");","module.exports = require(\"core-js/modules/web.dom-collections.for-each\");","module.exports = require(\"core-js/modules/es.string.search\");","module.exports = require(\"core-js/modules/es.string.replace\");","module.exports = require(\"element-ui/lib/option\");","// extracted by mini-css-extract-plugin","import mod from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BadgesGroup.vue?vue&type=style&index=0&id=3f3b3b02&scoped=true&lang=scss&\"; export default mod; export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BadgesGroup.vue?vue&type=style&index=0&id=3f3b3b02&scoped=true&lang=scss&\"","// extracted by mini-css-extract-plugin","// extracted by mini-css-extract-plugin","module.exports = require(\"element-ui/lib/theme-chalk/tag.css\");","module.exports = require(\"core-js/modules/es.array.last-index-of\");","module.exports = require(\"current-script-polyfill\");","module.exports = require(\"core-js/modules/es.array.from\");","module.exports = require(\"element-ui/lib/input\");","// extracted by mini-css-extract-plugin","module.exports = require(\"core-js/modules/es.object.entries\");","module.exports = require(\"core-js/modules/es.array.unscopables.flat\");","module.exports = require(\"core-js/modules/es.array.map\");","module.exports = require(\"core-js/modules/es.promise.finally\");","// This file is imported into lib/wc client bundles.\n\nif (typeof window !== 'undefined') {\n if (process.env.NEED_CURRENTSCRIPT_POLYFILL) {\n require('current-script-polyfill')\n }\n\n var i\n if ((i = window.document.currentScript) && (i = i.src.match(/(.+\\/)[^/]+\\.js(\\?.*)?$/))) {\n __webpack_public_path__ = i[1] // eslint-disable-line\n }\n}\n\n// Indicate to webpack that this file can be concatenated\nexport default null\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{ref:\"container\"},[(!_vm.drawerOpen)?_c('div',{staticClass:\"open-tab\",on:{\"click\":_vm.toggleDrawer}},[_c('i',{staticClass:\"el-icon-arrow-left\"})]):_vm._e(),_c('el-drawer',{staticClass:\"side-bar\",attrs:{\"custom-class\":\"my-drawer\",\"visible\":_vm.drawerOpen,\"appendToBody\":false,\"modal-append-to-body\":false,\"size\":\"550\",\"with-header\":false,\"wrapperClosable\":false,\"modal\":false},on:{\"update:visible\":function($event){_vm.drawerOpen=$event}}},[_c('div',{staticClass:\"box-card\"},[(_vm.drawerOpen)?_c('div',{staticClass:\"close-tab\",on:{\"click\":_vm.close}},[_c('i',{staticClass:\"el-icon-arrow-right\"})]):_vm._e(),_c('div',{staticClass:\"sidebar-container\"},[(_vm.tabs.length > 1)?_c('tabs',{attrs:{\"tabTitles\":_vm.tabs,\"activeId\":_vm.activeId},on:{\"titleClicked\":_vm.tabClicked}}):_vm._e(),_vm._l((_vm.tabs),function(tab){return [_c('sidebar-content',{directives:[{name:\"show\",rawName:\"v-show\",value:(tab.id===_vm.activeId),expression:\"tab.id===activeId\"}],key:tab.id,ref:tab.id,refInFor:true,staticClass:\"sidebar-content-container\",attrs:{\"contextCardEntry\":tab.contextCard,\"envVars\":_vm.envVars},on:{\"search-changed\":function($event){return _vm.searchChanged(tab.id, $event)}}})]})],2)])])],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nexport default function _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('el-card',{staticClass:\"content-card\",attrs:{\"body-style\":_vm.bodyStyle}},[_c('div',{staticClass:\"header\",attrs:{\"slot\":\"header\"},slot:\"header\"},[_c('el-input',{staticClass:\"search-input\",attrs:{\"placeholder\":\"Search\",\"clearable\":\"\"},on:{\"clear\":_vm.clearSearchClicked},nativeOn:{\"keyup\":function($event){return _vm.searchEvent($event)}},model:{value:(_vm.searchInput),callback:function ($$v) {_vm.searchInput=$$v},expression:\"searchInput\"}}),_c('el-button',{staticClass:\"button\",on:{\"click\":_vm.searchEvent}},[_vm._v(\"Search\")])],1),_c('SearchFilters',{ref:\"filtersRef\",staticClass:\"filters\",attrs:{\"entry\":_vm.filterEntry,\"envVars\":_vm.envVars},on:{\"filterResults\":_vm.filterUpdate,\"numberPerPage\":_vm.numberPerPageUpdate,\"loading\":_vm.filtersLoading,\"cascaderReady\":_vm.cascaderReady}}),_c('search-history',{ref:\"searchHistory\",on:{\"search\":_vm.searchHistorySearch}}),_c('div',{directives:[{name:\"loading\",rawName:\"v-loading\",value:(_vm.loadingCards),expression:\"loadingCards\"}],ref:\"content\",staticClass:\"content scrollbar\"},[(_vm.results.length === 0 && !_vm.loadingCards)?_c('div',{staticClass:\"error-feedback\"},[_vm._v(\" No results found - Please change your search / filter criteria. \")]):_vm._e(),_vm._l((_vm.results),function(result){return _c('div',{key:result.doi,staticClass:\"step-item\"},[_c('DatasetCard',{attrs:{\"entry\":result,\"envVars\":_vm.envVars}})],1)}),_c('el-pagination',{staticClass:\"pagination\",attrs:{\"current-page\":_vm.page,\"hide-on-single-page\":\"\",\"large\":\"\",\"layout\":\"prev, pager, next\",\"page-size\":_vm.numberPerPage,\"total\":_vm.numberOfHits},on:{\"update:currentPage\":function($event){_vm.page=$event},\"update:current-page\":function($event){_vm.page=$event},\"current-change\":_vm.pageChange}})],2)],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","export default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) {\n for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n }\n}","export default function _iterableToArray(iter) {\n if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter);\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance\");\n}","import arrayWithoutHoles from \"./arrayWithoutHoles\";\nimport iterableToArray from \"./iterableToArray\";\nimport nonIterableSpread from \"./nonIterableSpread\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || nonIterableSpread();\n}","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"filters\"},[_c('map-svg-sprite-color'),_c('transition',{attrs:{\"name\":\"el-zoom-in-top\"}},[_c('span',{directives:[{name:\"show\",rawName:\"v-show\",value:(_vm.showFilters),expression:\"showFilters\"}],staticClass:\"search-filters transition-box\"},[_c('custom-cascader',{ref:\"cascader\",staticClass:\"cascader\",attrs:{\"placeholder\":\"\",\"collapse-tags\":true,\"options\":_vm.options,\"props\":_vm.props,\"show-all-levels\":false,\"append-to-body\":false},on:{\"change\":function($event){return _vm.cascadeEvent($event)},\"expand-change\":_vm.cascadeExpandChange,\"tags-changed\":_vm.tagsChangedCallback},model:{value:(_vm.cascadeSelected),callback:function ($$v) {_vm.cascadeSelected=$$v},expression:\"cascadeSelected\"}}),(_vm.showFiltersText)?_c('div',{staticClass:\"filter-default-value\"},[_vm._v(\" Filters \")]):_vm._e(),_c('el-popover',{attrs:{\"title\":\"How do filters work?\",\"width\":\"250\",\"trigger\":\"hover\",\"append-to-body\":false,\"popper-class\":\"popover\"}},[_c('map-svg-icon',{staticClass:\"help\",attrs:{\"slot\":\"reference\",\"icon\":\"help\"},slot:\"reference\"}),_c('div',[_c('strong',[_vm._v(\"Within categories:\")]),_vm._v(\" OR \"),_c('br'),_vm._v(\" example: 'heart' OR 'colon' \"),_c('br'),_c('br'),_c('strong',[_vm._v(\"Between categories:\")]),_vm._v(\" AND \"),_c('br'),_vm._v(\" example: 'rat' AND 'lung' \")])],1)],1)]),_c('el-select',{staticClass:\"number-shown-select\",attrs:{\"placeholder\":\"10\"},on:{\"change\":function($event){return _vm.numberShownChanged($event)}},model:{value:(_vm.numberShown),callback:function ($$v) {_vm.numberShown=$$v},expression:\"numberShown\"}},_vm._l((_vm.numberDatasetsShown),function(item){return _c('el-option',{key:item,attrs:{\"label\":item,\"value\":item}})}),1),_c('span',{staticClass:\"dataset-results-feedback\"},[_vm._v(_vm._s(this.numberOfResultsText))])],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n}","import arrayWithHoles from \"./arrayWithHoles\";\nimport iterableToArray from \"./iterableToArray\";\nimport nonIterableRest from \"./nonIterableRest\";\nexport default function _toArray(arr) {\n return arrayWithHoles(arr) || iterableToArray(arr) || nonIterableRest();\n}","<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport { Cascader } from \"element-ui\";\r\n\r\nexport default {\r\n name: 'CustomCascader',\r\n extends: Cascader,\r\n methods:{\r\n //Modify this internal function to disable Show all tags\r\n computePresentTags() {\r\n const { isDisabled, leafOnly, showAllLevels, separator, collapseTags } = this;\r\n const checkedNodes = this.getCheckedNodes(leafOnly);\r\n const tags = [];\r\n const genTag = node => ({\r\n node,\r\n key: node.uid,\r\n text: node.getText(showAllLevels, separator),\r\n hitState: false,\r\n closable: !isDisabled && !node.isDisabled\r\n });\r\n let customNodes = checkedNodes.filter(node =>\r\n {\r\n return !(node.getText(showAllLevels, separator).includes(\"Show all\"));\r\n }\r\n );\r\n if (customNodes.length) {\r\n const [first, ...rest] = customNodes;\r\n const restCount = rest.length;\r\n tags.push(genTag(first));\r\n if (restCount) {\r\n if (collapseTags) {\r\n tags.push({\r\n key: -1,\r\n text: `+ ${restCount}`,\r\n closable: false\r\n });\r\n } else {\r\n rest.forEach(node => tags.push(genTag(node)));\r\n }\r\n }\r\n }\r\n this.checkedNodes = checkedNodes;\r\n this.presentTags = tags;\r\n this.$emit(\"tags-changed\", this.presentTags);\r\n }\r\n }\r\n}\r\n\r\n</script>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Cascader.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Cascader.vue?vue&type=script&lang=js&\"","/* globals __VUE_SSR_CONTEXT__ */\n\n// IMPORTANT: Do NOT use ES2015 features in this file (except for modules).\n// This module is a runtime utility for cleaner component module output and will\n// be included in the final webpack user bundle.\n\nexport default function normalizeComponent (\n scriptExports,\n render,\n staticRenderFns,\n functionalTemplate,\n injectStyles,\n scopeId,\n moduleIdentifier, /* server only */\n shadowMode /* vue-cli only */\n) {\n // Vue.extend constructor export interop\n var options = typeof scriptExports === 'function'\n ? scriptExports.options\n : scriptExports\n\n // render functions\n if (render) {\n options.render = render\n options.staticRenderFns = staticRenderFns\n options._compiled = true\n }\n\n // functional template\n if (functionalTemplate) {\n options.functional = true\n }\n\n // scopedId\n if (scopeId) {\n options._scopeId = 'data-v-' + scopeId\n }\n\n var hook\n if (moduleIdentifier) { // server build\n hook = function (context) {\n // 2.3 injection\n context =\n context || // cached call\n (this.$vnode && this.$vnode.ssrContext) || // stateful\n (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional\n // 2.2 with runInNewContext: true\n if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {\n context = __VUE_SSR_CONTEXT__\n }\n // inject component styles\n if (injectStyles) {\n injectStyles.call(this, context)\n }\n // register component module identifier for async chunk inferrence\n if (context && context._registeredComponents) {\n context._registeredComponents.add(moduleIdentifier)\n }\n }\n // used by ssr in case component is cached and beforeCreate\n // never gets called\n options._ssrRegister = hook\n } else if (injectStyles) {\n hook = shadowMode\n ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }\n : injectStyles\n }\n\n if (hook) {\n if (options.functional) {\n // for template-only hot-reload because in that case the render fn doesn't\n // go through the normalizer\n options._injectStyles = hook\n // register for functioal component in vue file\n var originalRender = options.render\n options.render = function renderWithStyleInjection (h, context) {\n hook.call(context)\n return originalRender(h, context)\n }\n } else {\n // inject component registration as beforeCreate hook\n var existing = options.beforeCreate\n options.beforeCreate = existing\n ? [].concat(existing, hook)\n : [hook]\n }\n }\n\n return {\n exports: scriptExports,\n options: options\n }\n}\n","var render, staticRenderFns\nimport script from \"./Cascader.vue?vue&type=script&lang=js&\"\nexport * from \"./Cascader.vue?vue&type=script&lang=js&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports","export default {\r\n 'homo sapiens': 'Human',\r\n 'rattus norvegicus': 'Rat',\r\n 'mus musculus': 'Mouse',\r\n 'sus scrofa domesticus': 'Pig',\r\n 'sus scrofa': 'Boar',\r\n 'felis catus': 'Cat'\r\n}\r\n","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}","/* eslint-disable no-alert, no-console */\r\nimport algoliasearch from 'algoliasearch'\r\n\r\n// export `createAlgoliaClient` to use it in page components\r\nexport class AlgoliaClient {\r\n constructor(algoliaId, algoliaKey, PENNSIEVE_API_LOCATION = 'https://api.pennsieve.io') {\r\n this.client = algoliasearch(\r\n algoliaId,\r\n algoliaKey\r\n )\r\n this.PENNSIEVE_API_LOCATION = PENNSIEVE_API_LOCATION\r\n this.anatomyFacetLabels = []\r\n }\r\n initIndex(ALGOLIA_INDEX) {\r\n this.index = this.client.initIndex(ALGOLIA_INDEX);\r\n }\r\n\r\n getAlgoliaFacets(propPathMapping) {\r\n const map = new Map(Object.entries(propPathMapping));\r\n const facetPropPaths = Array.from(map.keys());\r\n let facetData = []\r\n let facetId = 0\r\n return this.index\r\n .search('', {\r\n sortFacetValuesBy: 'alpha',\r\n facets: facetPropPaths\r\n })\r\n .then(response => {\r\n facetPropPaths.map((facetPropPath) => {\r\n var children = []\r\n const responseFacets = response.facets\r\n if (responseFacets === undefined) { return }\r\n const responseFacetChildren =\r\n responseFacets[facetPropPath] == undefined\r\n ? {}\r\n : responseFacets[facetPropPath]\r\n Object.keys(responseFacetChildren).map(facet => {\r\n children.push({\r\n label: facet,\r\n id: facetId++,\r\n facetPropPath: facetPropPath\r\n })\r\n })\r\n if (children.length > 0) {\r\n facetData.push({\r\n label: map.get(facetPropPath),\r\n id: facetId++,\r\n children: children,\r\n key: facetPropPath\r\n })\r\n }\r\n })\r\n return facetData\r\n })\r\n }\r\n\r\n // Returns all DOIs of all versions for a given discover dataset\r\n _discoverAllDois(discoverId, PENNSIEVE_API_LOCATION = 'https://api.pennsieve.io') {\r\n return new Promise(resolve => {\r\n fetch(`${PENNSIEVE_API_LOCATION}/discover/datasets/${discoverId}/versions`).then(r => r.json()).then(dataset => {\r\n resolve(dataset.map(version => version.doi))\r\n })\r\n })\r\n }\r\n\r\n // Get all dois given a list of discoverIds\r\n _expandDois(discoverIds, PENNSIEVE_API_LOCATION = 'https://api.pennsieve.io') {\r\n return new Promise(resolve => {\r\n let promiseList = discoverIds.map(discoverId => this._discoverAllDois(discoverId, PENNSIEVE_API_LOCATION))\r\n Promise.all(promiseList).then((values) => {\r\n resolve(values.flat())\r\n });\r\n })\r\n }\r\n\r\n _processResultsForCards(results) {\r\n let newResults = []\r\n let newResult = {}\r\n for (let res of results) {\r\n newResult = { ...res }\r\n newResult = {\r\n doi: res.item.curie.split(':')[1],\r\n name: res.item.name,\r\n description: res.item.description,\r\n updated: res.pennsieve ? res.pennsieve.updatedAt : undefined,\r\n publishDate: res.pennsieve ? res.pennsieve.publishDate : undefined,\r\n datasetId: res.objectID,\r\n detailsReady: false\r\n }\r\n newResults.push(newResult)\r\n }\r\n return newResults\r\n }\r\n\r\n _processAnatomy(hits) {\r\n let foundKeyWords = []\r\n let foundLabels = []\r\n let uniqueLabels = []\r\n let uniqueKeywords = []\r\n hits.forEach(hit => {\r\n if (hit.item && hit.item.keywords) {\r\n hit.item.keywords.forEach(keywordObj => {\r\n let keyword = keywordObj.keyword.toUpperCase()\r\n if (keyword.includes('UBERON') || keyword.includes('ILX')) {\r\n foundKeyWords.push(this._processUberonURL(keyword))\r\n }\r\n })\r\n }\r\n if (hit.anatomy && hit.anatomy.organ ) {\r\n hit.anatomy.organ.forEach(anatomy => {\r\n if (anatomy.curie) {\r\n foundKeyWords.push(anatomy.curie)\r\n foundLabels.push(anatomy.name)\r\n }\r\n })\r\n }\r\n })\r\n uniqueKeywords = [...new Set(foundKeyWords) ]\r\n uniqueLabels = [...new Set(foundLabels) ]\r\n this.anatomyFacetLabels = uniqueLabels\r\n return uniqueKeywords\r\n }\r\n\r\n _processUberonURL(url) {\r\n let ub = url.split('/').pop()\r\n return ub.replace('_', ':')\r\n }\r\n\r\n /**\r\n * Get Search results\r\n * This is using fetch from the Algolia API\r\n */\r\n search(filter, query = '', hitsperPage = 10, page = 1) {\r\n return new Promise(resolve => {\r\n this.index\r\n .search(query, {\r\n facets: ['*'],\r\n hitsPerPage: hitsperPage,\r\n page: page - 1,\r\n filters: filter,\r\n attributesToHighlight: [],\r\n attributesToRetrieve: [\r\n 'pennsieve.publishDate',\r\n 'pennsieve.updatedAt',\r\n 'item.curie',\r\n 'item.name',\r\n 'item.description',\r\n 'objectID',\r\n ],\r\n })\r\n .then(response => {\r\n let searchData = {\r\n items: this._processResultsForCards(response.hits),\r\n total: response.nbHits,\r\n discoverIds: response.hits.map(r => r.pennsieve ? r.pennsieve.identifier : r.objectID),\r\n dois: response.hits.map(r => r.item.curie.split(':')[1])\r\n }\r\n resolve(searchData)\r\n })\r\n })\r\n }\r\n\r\n /**\r\n * Get key words\r\n * This is used to return all keywords for a given search. Note that you often want the hits per page to be maxed out\r\n */\r\n anatomyInSearch(filter, query = '', hitsperPage = 999999, page = 1) {\r\n return new Promise(resolve => {\r\n this.index\r\n .search(query, {\r\n facets: ['*'],\r\n hitsPerPage: hitsperPage,\r\n page: page - 1,\r\n filters: filter,\r\n attributesToHighlight: [],\r\n attributesToRetrieve: [\r\n 'item.keywords.keyword',\r\n 'anatomy.organ.name',\r\n 'anatomy.organ.curie'\r\n ],\r\n })\r\n .then(response => {\r\n let anatomyAsUberons = this._processAnatomy(response.hits)\r\n resolve(anatomyAsUberons)\r\n })\r\n })\r\n }\r\n}\r\n","/* eslint-disable no-alert, no-console */\r\n\r\n// Mapping between display categories and their Algolia index property path\r\n// Used for populating the Dataset Search Results facet menu dynamically\r\nexport const facetPropPathMapping = {\r\n 'anatomy.organ.name' : 'Anatomical Structure',\r\n 'organisms.primary.species.name' : 'Species',\r\n 'item.modalities.keyword' : 'Experimental Approach',\r\n 'attributes.subject.sex.value' : 'Sex',\r\n 'attributes.subject.ageCategory.value' : 'Age Categories',\r\n 'item.types.name' : 'Data type',\r\n}\r\n\r\n// Same as above, but these show on the sidebar filters\r\nexport const shownFilters = {\r\n 'anatomy.organ.name' : 'Anatomical Structure',\r\n 'organisms.primary.species.name' : 'Species',\r\n 'attributes.subject.sex.value' : 'Sex',\r\n 'attributes.subject.ageCategory.value' : 'Age Categories',\r\n 'item.types.name' : 'Data type',\r\n}\r\n\r\n/* Returns filter for searching algolia. All facets of the same category are joined with OR,\r\n * and each of those results is then joined with an AND.\r\n * i.e. (color:blue OR color:red) AND (shape:circle OR shape:red) */\r\nexport function getFilters(selectedFacetArray=undefined) {\r\n // return all datasets if no filter\r\n if (selectedFacetArray === undefined) {\r\n return 'NOT item.published.status:embargo'\r\n }\r\n\r\n // Switch the 'term' attribute to 'label' if 'label' does not exist \r\n selectedFacetArray.forEach(f=>f.label=f.facet)\r\n \r\n\r\n let facets = removeShowAllFacets(selectedFacetArray)\r\n\r\n let filters = \"NOT item.published.status:embargo\";\r\n filters = `(${filters}) AND `;\r\n\r\n const facetPropPaths = Object.keys(facetPropPathMapping);\r\n facetPropPaths.map((facetPropPath) => {\r\n const facetsToBool = facets.filter(\r\n (facet) => facet.facetPropPath == facetPropPath\r\n );\r\n let orFilters = \"\";\r\n let andFilters = \"\";\r\n facetsToBool.map((facet) => {\r\n if (facet.AND){\r\n andFilters += `AND \"${facetPropPath}\":\"${facet.label}\"`;\r\n } else {\r\n orFilters += `\"${facetPropPath}\":\"${facet.label}\" OR `;\r\n }\r\n });\r\n if (orFilters == \"\" && andFilters ==\"\") {\r\n return;\r\n }\r\n orFilters = `(${orFilters.substring(0, orFilters.lastIndexOf(\" OR \"))})` // remove last OR\r\n\r\n filters += `${orFilters + andFilters} AND `; // Put them together\r\n // (Note that we add an extra AND in case there are facets at a higher level)\r\n\r\n filters = filters.split('()AND ').join(''); // Handle case where there where no OR facets\r\n });\r\n return filters.substring(0, filters.lastIndexOf(\" AND \"));\r\n}\r\n\r\nfunction removeShowAllFacets(facetArray){\r\n return facetArray.filter( f => f.label !== 'Show all')\r\n}","<template>\r\n <div class=\"filters\">\r\n <map-svg-sprite-color />\r\n <transition name=\"el-zoom-in-top\">\r\n <span v-show=\"showFilters\" class=\"search-filters transition-box\">\r\n <custom-cascader\r\n class=\"cascader\"\r\n ref=\"cascader\"\r\n v-model=\"cascadeSelected\"\r\n placeholder\r\n :collapse-tags=\"true\"\r\n :options=\"options\"\r\n :props=\"props\"\r\n @change=\"cascadeEvent($event)\"\r\n @expand-change=\"cascadeExpandChange\"\r\n :show-all-levels=\"false\"\r\n :append-to-body=\"false\"\r\n @tags-changed=\"tagsChangedCallback\"\r\n ></custom-cascader>\r\n <div v-if=\"showFiltersText\" class=\"filter-default-value\">\r\n Filters\r\n </div>\r\n <el-popover\r\n title=\"How do filters work?\"\r\n width=\"250\"\r\n trigger=\"hover\"\r\n :append-to-body=false\r\n popper-class=\"popover\"\r\n >\r\n <map-svg-icon slot=\"reference\" icon=\"help\" class=\"help\"/>\r\n <div >\r\n <strong>Within categories:</strong> OR \r\n <br/>\r\n example: 'heart' OR 'colon'\r\n <br/>\r\n <br/>\r\n <strong>Between categories:</strong> AND\r\n <br/>\r\n example: 'rat' AND 'lung'\r\n </div>\r\n </el-popover>\r\n \r\n </span>\r\n </transition>\r\n\r\n <el-select\r\n class=\"number-shown-select\"\r\n v-model=\"numberShown\"\r\n placeholder=\"10\"\r\n @change=\"numberShownChanged($event)\"\r\n >\r\n <el-option\r\n v-for=\"item in numberDatasetsShown\"\r\n :key=\"item\"\r\n :label=\"item\"\r\n :value=\"item\"\r\n ></el-option>\r\n </el-select>\r\n <span class=\"dataset-results-feedback\">{{ this.numberOfResultsText }}</span>\r\n </div>\r\n</template>\r\n\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport { Option, Select, Popover } from \"element-ui\";\r\nimport CustomCascader from \"./Cascader\";\r\nimport lang from \"element-ui/lib/locale/lang/en\";\r\nimport locale from \"element-ui/lib/locale\";\r\nimport speciesMap from \"./species-map\";\r\nimport { MapSvgIcon, MapSvgSpriteColor } from \"@abi-software/svg-sprite\";\r\n\r\nimport {AlgoliaClient} from \"../algolia/algolia.js\";\r\nimport {facetPropPathMapping} from \"../algolia/utils.js\";\r\n\r\nlocale.use(lang);\r\nVue.use(Option);\r\nVue.use(Select);\r\nVue.use(Popover)\r\n\r\nconst capitalise = function (txt) {\r\n return txt.charAt(0).toUpperCase() + txt.slice(1);\r\n};\r\n\r\nconst convertReadableLabel = function (original) {\r\n const name = original.toLowerCase();\r\n if (speciesMap[name]) {\r\n return capitalise(speciesMap[name]);\r\n } else {\r\n return capitalise(name);\r\n }\r\n};\r\n\r\nexport default {\r\n name: \"SearchFilters\",\r\n components: {\r\n CustomCascader,\r\n MapSvgIcon,\r\n MapSvgSpriteColor,\r\n },\r\n props: {\r\n /**\r\n * Object containing information for\r\n * the required viewing.\r\n */\r\n entry: Object,\r\n envVars: {\r\n type: Object,\r\n default: ()=>{}\r\n },\r\n },\r\n data: function () {\r\n return {\r\n cascaderIsReady: false,\r\n previousShowAllChecked: {\r\n species: false,\r\n gender: false,\r\n organ: false,\r\n datasets: false,\r\n },\r\n showFilters: true,\r\n showFiltersText: true,\r\n cascadeSelected: [],\r\n cascadeSelectedWithBoolean: [], \r\n numberShown: 10,\r\n filters: [],\r\n facets: [\"Species\", \"Gender\", \"Organ\", \"Datasets\"],\r\n numberDatasetsShown: [\"10\", \"20\", \"50\"],\r\n props: { multiple: true },\r\n options: [\r\n {\r\n value: \"Species\",\r\n label: \"Species\",\r\n children: [{}],\r\n },\r\n ],\r\n };\r\n },\r\n computed: {\r\n numberOfResultsText: function () {\r\n return `${this.entry.numberOfHits} results | Showing`;\r\n },\r\n },\r\n methods: {\r\n createCascaderItemValue: function (term, facet) {\r\n if (facet) return term + \">\" + facet;\r\n else return term;\r\n },\r\n populateCascader: function () {\r\n return new Promise((resolve) => {\r\n // Algolia facet serach\r\n this.algoliaClient.getAlgoliaFacets(facetPropPathMapping)\r\n .then((data) => {\r\n this.facets = data;\r\n this.options = data;\r\n\r\n // create top level of options in cascader\r\n this.options.forEach((facet, i) => {\r\n this.options[i].label = convertReadableLabel(facet.label);\r\n this.options[i].value = this.createCascaderItemValue(\r\n facet.key,\r\n undefined\r\n );\r\n\r\n // put \"Show all\" as first option\r\n this.options[i].children.unshift({\r\n value: this.createCascaderItemValue(\"Show all\"),\r\n label: \"Show all\",\r\n });\r\n\r\n // populate second level of options \r\n this.options[i].children.forEach((facetItem, j) => {\r\n this.options[i].children[j].label = convertReadableLabel(\r\n facetItem.label\r\n );\r\n this.options[i].children[j].value =\r\n this.createCascaderItemValue(facet.label, facetItem.label);\r\n });\r\n });\r\n })\r\n .finally(() => {\r\n resolve();\r\n });\r\n });\r\n },\r\n tagsChangedCallback: function (presentTags) {\r\n if (presentTags.length > 0) {\r\n this.showFiltersText = false;\r\n } else {\r\n this.showFiltersText = true;\r\n }\r\n },\r\n // cascadeEvent: initiate searches based off cascader changes\r\n cascadeEvent: function (event) {\r\n if (event) {\r\n // Check for show all in selected cascade options\r\n event = this.showAllEventModifier(event);\r\n\r\n // Create results for the filter update \r\n let filterKeys = event.filter( selection => selection !== undefined).map( fs => ({\r\n facetPropPath: fs[0], \r\n facet: fs[1].split(\">\")[1],\r\n term: fs[1].split(\">\")[0], \r\n AND: fs[2] // for setting the boolean\r\n }))\r\n\r\n // Move results from arrays to object for use on scicrunch (note that we remove 'duplicate' as that is only needed for filter keys)\r\n let filters = event.filter( selection => selection !== undefined).map( fs => {\r\n let propPath = fs[0].includes('duplicate') ? fs[0].split('duplicate')[0] : fs[0]\r\n return {\r\n facetPropPath: propPath, \r\n facet: fs[1].split(\">\")[1],\r\n term: fs[1].split(\">\")[0], \r\n AND: fs[2] // for setting the boolean\r\n }\r\n })\r\n\r\n\r\n this.$emit('loading', true) // let sidebarcontent wait for the requests\r\n\r\n this.$emit(\"filterResults\", filters); // emit filters for apps above sidebar\r\n this.setCascader(filterKeys); //update our cascader v-model if we modified the event\r\n this.makeCascadeLabelsClickable();\r\n }\r\n },\r\n // showAllEventModifier: Modifies a cascade event to unclick all selections in category if \"show all\" is clicked. Also unchecks \"Show all\" if any secection is clicked\r\n // *NOTE* Does NOT remove 'Show all' selections from showing in 'cascadeSelected'\r\n showAllEventModifier: function (event) {\r\n // check if show all is in the cascader checked option list\r\n let hasShowAll = event\r\n .map((ev) => (ev ? ev[1].toLowerCase().includes(\"show all\") : false))\r\n .includes(true);\r\n // remove all selected options below the show all if checked\r\n if (hasShowAll) {\r\n let modifiedEvent = [];\r\n let facetMaps = {};\r\n //catagorised different facet items\r\n for (const i in event) {\r\n if (facetMaps[event[i][0]] === undefined) facetMaps[event[i][0]] = [];\r\n facetMaps[event[i][0]].push(event[i]);\r\n }\r\n // go through each facets\r\n for (const facet in facetMaps) {\r\n let showAll = undefined;\r\n // Find the show all item if any\r\n for (let i = facetMaps[facet].length - 1; i >= 0; i--) {\r\n if (facetMaps[facet][i][1].toLowerCase().includes(\"show all\")) {\r\n //seperate the showAll item and the rest\r\n showAll = facetMaps[facet].splice(i, 1)[0];\r\n break;\r\n }\r\n }\r\n if (showAll) {\r\n if (this.previousShowAllChecked[facet]) {\r\n //Unset the show all if it was present previously\r\n //and there are other items\r\n if (facetMaps[facet].length > 0)\r\n modifiedEvent.push(...facetMaps[facet]);\r\n else modifiedEvent.push(showAll);\r\n } else {\r\n //showAll is turned on\r\n modifiedEvent.push(showAll);\r\n }\r\n } else {\r\n modifiedEvent.push(...facetMaps[facet]);\r\n }\r\n }\r\n //Make sure the expanded item are sorted first.\r\n return modifiedEvent.sort((a, b) => {\r\n if (this.__expandItem__) {\r\n if (a[0] == this.__expandItem__) {\r\n if (b[0] == this.__expandItem__) {\r\n return 0;\r\n } else {\r\n return -1;\r\n }\r\n } else if (b[0] == this.__expandItem__) {\r\n if (a[0] == this.__expandItem__) {\r\n return 0;\r\n } else {\r\n return 1;\r\n }\r\n } else {\r\n return 0;\r\n }\r\n } else return 0;\r\n });\r\n }\r\n return event;\r\n },\r\n cascadeExpandChange: function (event) {\r\n //work around as the expand item may change on modifying the cascade props\r\n this.__expandItem__ = event;\r\n this.makeCascadeLabelsClickable();\r\n },\r\n numberShownChanged: function (event) {\r\n this.$emit(\"numberPerPage\", parseInt(event));\r\n },\r\n updatePreviousShowAllChecked: function (options) {\r\n //Reset the states\r\n for (const facet in this.previousShowAllChecked) {\r\n this.previousShowAllChecked[facet] = false;\r\n }\r\n options.forEach((element) => {\r\n if (element[1].toLowerCase().includes(\"show all\"))\r\n this.previousShowAllChecked[element[0]] = true;\r\n });\r\n },\r\n // setCascader: Clears previous selections and takes in an array of facets to select: filterFacets\r\n // facets are in the form:\r\n // {\r\n // facetPropPath: 'anatomy.organ.name',\r\n // term: 'Sex',\r\n // facet: 'Male'\r\n // AND: true // Optional value for setting the boolean within a facet\r\n // }\r\n setCascader: function (filterFacets) {\r\n //Do not set the value unless it is ready\r\n if (this.cascaderIsReady && filterFacets && filterFacets.length != 0) {\r\n this.cascadeSelected = filterFacets.map(e => {\r\n return [\r\n e.facetPropPath,\r\n this.createCascaderItemValue(capitalise(e.term), e.facet),\r\n ]\r\n });\r\n\r\n // Unforttunately the cascader is very particular about it's v-model\r\n // to get around this we create a clone of it and use this clone for adding our boolean information\r\n this.cascadeSelectedWithBoolean= filterFacets.map(e => {\r\n return [\r\n e.facetPropPath,\r\n this.createCascaderItemValue(capitalise(e.term), e.facet),\r\n e.AND\r\n ]\r\n });\r\n this.updatePreviousShowAllChecked(this.cascadeSelected);\r\n }\r\n },\r\n addFilter: function (filter) {\r\n //Do not set the value unless it is ready\r\n if (this.cascaderIsReady && filter) {\r\n if (this.validateFilter(filter)) {\r\n this.cascadeSelected.filter(f=>f.term != filter.term)\r\n this.cascadeSelected.push([filter.facetPropPath, this.createCascaderItemValue(filter.term, filter.facet), filter.AND])\r\n this.cascadeSelectedWithBoolean.push([filter.facetPropPath, this.createCascaderItemValue(filter.term, filter.facet), filter.AND])\r\n // The 'AND' her is to set the boolean value when we search on the filters. It can be undefined without breaking anything\r\n return true;\r\n }\r\n }\r\n },\r\n initiateSearch: function() {\r\n this.cascadeEvent(this.cascadeSelectedWithBoolean)\r\n },\r\n // checkShowAllBoxes: Checks each 'Show all' cascade option by using the setCascader function\r\n checkShowAllBoxes: function(){\r\n this.setCascader(\r\n this.options.map(option => {\r\n return {\r\n facetPropPath: option.value,\r\n term: option.label,\r\n facet: 'Show all'\r\n }\r\n })\r\n )\r\n },\r\n makeCascadeLabelsClickable: function () {\r\n // Next tick allows the cascader menu to change\r\n this.$nextTick(() => {\r\n this.$refs.cascader.$el\r\n .querySelectorAll(\".el-cascader-node__label\")\r\n .forEach((el) => {\r\n // step through each cascade label\r\n el.onclick = function () {\r\n const checkbox = this.previousElementSibling;\r\n if (checkbox) {\r\n if (!checkbox.parentElement.attributes[\"aria-owns\"]) {\r\n // check if we are at the lowest level of cascader\r\n this.previousElementSibling.click(); // Click the checkbox\r\n }\r\n }\r\n };\r\n });\r\n });\r\n },\r\n /**\r\n * Validate ther filter term to make sure the term is correct\r\n */\r\n validateFilter: function(filter) {\r\n if (filter && filter.facet && filter.term) {\r\n const item = this.createCascaderItemValue(filter.term, filter.facet);\r\n const facet = this.options.find(element => element.value === filter.facetPropPath);\r\n if (facet) {\r\n const filter = facet.children.find(element => element.value === item);\r\n if (filter)\r\n return true;\r\n }\r\n }\r\n return false;\r\n },\r\n /**\r\n * Return a list of valid filers given a list of filters, \r\n */\r\n getValidatedFilters: function (filters) {\r\n if (filters) {\r\n if (this.cascaderIsReady) {\r\n const result = [];\r\n filters.forEach(filter => {\r\n if (this.validateFilter(filter)) {\r\n result.push(filter);\r\n }\r\n });\r\n return result;\r\n } else return filters;\r\n }\r\n return [];\r\n },\r\n },\r\n mounted: function () {\r\n this.algoliaClient = new AlgoliaClient(this.envVars.ALGOLIA_ID, this.envVars.ALGOLIA_KEY, this.envVars.PENNSIEVE_API_LOCATION);\r\n this.algoliaClient.initIndex(this.envVars.ALGOLIA_INDEX);\r\n this.populateCascader().then(() => {\r\n this.cascaderIsReady = true;\r\n this.checkShowAllBoxes();\r\n this.setCascader(this.entry.filterFacets);\r\n this.makeCascadeLabelsClickable();\r\n this.$emit(\"cascaderReady\");\r\n });\r\n },\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/option\";\r\n@import \"~element-ui/packages/theme-chalk/src/popover\";\r\n@import \"~element-ui/packages/theme-chalk/src/select\";\r\n\r\n.filter-default-value {\r\n pointer-events: none;\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n padding-top: 10px;\r\n padding-left: 16px;\r\n}\r\n\r\n.help {\r\n width: 24px !important;\r\n height: 24px;\r\n transform: scale(1.1);\r\n cursor: pointer;\r\n}\r\n\r\n.popover {\r\n color: rgb(48, 49, 51);\r\n font-family: Asap;\r\n margin: 12px;\r\n}\r\n\r\n.filter-icon-inside {\r\n width: 12px !important;\r\n height: 12px !important;\r\n color: #292b66;\r\n transform: scale(2) !important;\r\n margin-bottom: 0px !important;\r\n}\r\n\r\n.cascader {\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-weight: 500;\r\n font-stretch: normal;\r\n font-style: normal;\r\n line-height: normal;\r\n letter-spacing: normal;\r\n color: #292b66;\r\n text-align: center;\r\n padding-bottom: 6px;\r\n}\r\n\r\n.cascader ::v-deep .el-cascder-panel {\r\n max-height: 500px;\r\n}\r\n\r\n.cascader::v-deep .el-scrollbar__wrap {\r\n overflow-x: hidden;\r\n margin-bottom: 2px !important;\r\n}\r\n\r\n.cascader ::v-deep li[aria-owns*=\"cascader\"] > .el-checkbox {\r\n display: none;\r\n}\r\n\r\n.dataset-results-feedback {\r\n float: right;\r\n text-align: right;\r\n color: rgb(48, 49, 51);\r\n font-family: Asap;\r\n font-size: 18px;\r\n font-weight: 500;\r\n padding-top: 8px;\r\n}\r\n\r\n.search-filters {\r\n position: relative;\r\n float: left;\r\n padding-right: 15px;\r\n}\r\n\r\n.number-shown-select {\r\n float: right;\r\n}\r\n\r\n.number-shown-select ::v-deep .el-input__inner {\r\n width: 68px;\r\n height: 40px;\r\n color: rgb(48, 49, 51);\r\n}\r\n\r\n.search-filters ::v-deep .el-cascader-node.is-active {\r\n color: $app-primary-color;\r\n}\r\n\r\n.search-filters ::v-deep .el-cascader-node.in-active-path {\r\n color: $app-primary-color;\r\n}\r\n\r\n.search-filters ::v-deep .el-checkbox__input.is-checked > .el-checkbox__inner {\r\n background-color: $app-primary-color;\r\n border-color: $app-primary-color;\r\n}\r\n\r\n.cascader ::v-deep .el-cascader-menu:nth-child(2) .el-cascader-node:first-child {\r\n border-bottom: 1px solid #e4e7ed;\r\n}\r\n\r\n.cascader ::v-deep .el-cascader-node__label {\r\n text-align: left;\r\n}\r\n\r\n.filters ::v-deep .el-popover {\r\n background: #f3ecf6 !important;\r\n border: 1px solid $app-primary-color;\r\n border-radius: 4px;\r\n color: #303133 !important;\r\n font-size: 12px;\r\n line-height: 18px;\r\n}\r\n\r\n.filters ::v-deep .el-popover[x-placement^=\"top\"] .popper__arrow {\r\n border-top-color: $app-primary-color;\r\n border-bottom-width: 0;\r\n}\r\n.filters ::v-deep .el-popover[x-placement^=\"top\"] .popper__arrow::after {\r\n border-top-color: #f3ecf6;\r\n border-bottom-width: 0;\r\n}\r\n\r\n.filters ::v-deep .el-popover[x-placement^=\"bottom\"] .popper__arrow {\r\n border-top-width: 0;\r\n border-bottom-color: $app-primary-color;\r\n}\r\n.filters ::v-deep .el-popover[x-placement^=\"bottom\"] .popper__arrow::after {\r\n border-top-width: 0;\r\n border-bottom-color: #f3ecf6;\r\n}\r\n\r\n.filters ::v-deep .el-popover[x-placement^=\"right\"] .popper__arrow {\r\n border-right-color: $app-primary-color;\r\n border-left-width: 0;\r\n}\r\n.filters ::v-deep .el-popover[x-placement^=\"right\"] .popper__arrow::after {\r\n border-right-color: #f3ecf6;\r\n border-left-width: 0;\r\n}\r\n\r\n.filters ::v-deep .el-popover[x-placement^=\"left\"] .popper__arrow {\r\n border-right-width: 0;\r\n border-left-color: $app-primary-color;\r\n}\r\n.filters ::v-deep .el-popover[x-placement^=\"left\"] .popper__arrow::after {\r\n border-right-width: 0;\r\n border-left-color: #f3ecf6;\r\n}\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchFilters.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchFilters.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SearchFilters.vue?vue&type=template&id=228b9f2c&scoped=true&\"\nimport script from \"./SearchFilters.vue?vue&type=script&lang=js&\"\nexport * from \"./SearchFilters.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SearchFilters.vue?vue&type=style&index=0&id=228b9f2c&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"228b9f2c\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"container\"},[_vm._l((_vm.reversedSearchHistory),function(item,i){return [(i < 3)?_c('el-tag',{key:i,staticClass:\"search-tag\",on:{\"click\":function($event){return _vm.search(item)}}},[_vm._v(_vm._s(item.search)+\" \")]):_vm._e()]}),(_vm.reversedSearchHistory.length > 0)?_c('el-select',{staticClass:\"m-2 search-select\",attrs:{\"value\":_vm.selectValue,\"placeholder\":\"Full search History\",\"size\":\"small\",\"popper-class\":\"sidebar-search-select-popper\"},on:{\"change\":_vm.selectChange}},_vm._l((_vm.cascaderOptions),function(item,i){return _c('el-option',{key:i,attrs:{\"label\":item.label,\"value\":item.value}})}),1):_vm._e()],2)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","import Vue from 'vue';\r\nconst EventBus = new Vue();\r\nexport default EventBus;\r\n","<template>\r\n <div class=\"container\">\r\n <!-- <span v-if=\"reversedSearchHistory.length > 0\" class=\"title\"> Search History </span> -->\r\n <template v-for=\"(item, i) in reversedSearchHistory\">\r\n <el-tag class=\"search-tag\" v-if=\"i < 3\" v-bind:key=\"i\" @click=\"search(item)\">{{ item.search }} </el-tag>\r\n </template>\r\n <el-select \r\n v-if=\"reversedSearchHistory.length > 0\" \r\n :value=\"selectValue\" \r\n class=\"m-2 search-select\" \r\n placeholder=\"Full search History\" \r\n size=\"small\"\r\n popper-class=\"sidebar-search-select-popper\"\r\n @change=\"selectChange\"\r\n >\r\n <el-option\r\n v-for=\"(item, i) in cascaderOptions\"\r\n :key=\"i\"\r\n :label=\"item.label\"\r\n :value=\"item.value\"\r\n />\r\n </el-select>\r\n </div>\r\n\r\n</template>\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport {\r\n Tag,\r\n Select,\r\n} from \"element-ui\";\r\n\r\nVue.use(Tag);\r\nVue.use(Select);\r\nimport EventBus from './EventBus';\r\n\r\n// remove duplicates by stringifying the objects\r\nconst removeDuplicates = function(arrayOfAnything){\r\n return [...new Set(arrayOfAnything.map(e => JSON.stringify(e)))].map(e => JSON.parse(e)) \r\n}\r\n\r\nexport default {\r\n name: 'SearchHistory',\r\n data() {\r\n return {\r\n searchHistory: [],\r\n selectValue: 'Full search history'\r\n }\r\n\r\n },\r\n computed: {\r\n reversedSearchHistory: function(){\r\n return removeDuplicates(this.searchHistory.slice().reverse().filter(item => item.search !== ''))\r\n },\r\n cascaderOptions: function(){\r\n return this.reversedSearchHistory.map(item => {\r\n return {\r\n value: item.search,\r\n label: item.search\r\n }\r\n })\r\n }\r\n },\r\n methods: {\r\n getSearchHistory() {\r\n if (localStorage.getItem('sparc.science-sidebar-search-history')) {\r\n this.searchHistory = JSON.parse(localStorage.getItem('sparc.science-sidebar-search-history'));\r\n } else {\r\n this.searchHistory = [];\r\n }\r\n },\r\n clearSearchHistory() {\r\n localStorage.removeItem('sparc.science-sidebar-search-history');\r\n this.searchHistory = [];\r\n },\r\n addSearchToHistory(filters, search) {\r\n filters = [] // disable filters for now\r\n search = search.trim() // remove whitespace\r\n let searchHistory = JSON.parse(localStorage.getItem('sparc.science-sidebar-search-history'));\r\n if (searchHistory) {\r\n searchHistory.push({filters: filters, search: search});\r\n this.searchHistory = removeDuplicates(searchHistory)\r\n localStorage.setItem('sparc.science-sidebar-search-history', JSON.stringify(searchHistory));\r\n } else {\r\n localStorage.setItem('sparc.science-sidebar-search-history', JSON.stringify([{filters: filters, search: search}]));\r\n }\r\n },\r\n search: function(item) {\r\n this.$emit(\"search\", item);\r\n },\r\n selectChange: function(value) {\r\n this.selectValue = value;\r\n this.search({search: value})\r\n }\r\n },\r\n mounted: function () {\r\n this.getSearchHistory();\r\n EventBus.$on('search-changed', (data) => {\r\n this.setSearchHistory(data);\r\n })\r\n }\r\n}\r\n</script>\r\n\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/tag\";\r\n\r\n.container {\r\n}\r\n\r\n.search-tag {\r\n margin: 0 5px 5px 0;\r\n cursor: pointer;\r\n max-width: 100px;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n}\r\n\r\n.title {\r\n font-size: 14px;\r\n font-weight: bold;\r\n margin-right: 5px;\r\n // center text vertically\r\n display: flex;\r\n align-items: center;\r\n \r\n}\r\n\r\n.search-select {\r\n float: right;\r\n}\r\n</style>\r\n\r\n<style lang=\"scss\">\r\n.sidebar-search-select-popper {\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-weight: 500;\r\n font-stretch: normal;\r\n font-style: normal;\r\n line-height: normal;\r\n letter-spacing: normal;\r\n color: #292b66;\r\n max-width: 200px;\r\n}\r\n</style>","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SearchHistory.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SearchHistory.vue?vue&type=template&id=84745c26&scoped=true&\"\nimport script from \"./SearchHistory.vue?vue&type=script&lang=js&\"\nexport * from \"./SearchHistory.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SearchHistory.vue?vue&type=style&index=0&id=84745c26&scoped=true&lang=scss&\"\nimport style1 from \"./SearchHistory.vue?vue&type=style&index=1&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"84745c26\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{ref:\"container\",staticClass:\"dataset-card-container\"},[_c('div',{ref:\"card\",staticClass:\"dataset-card\"},[_c('div',{staticClass:\"seperator-path\"}),_c('div',{directives:[{name:\"loading\",rawName:\"v-loading\",value:(_vm.loading),expression:\"loading\"}],staticClass:\"card\"},[_c('span',{staticClass:\"card-left\"},[(!_vm.loading && _vm.discoverId)?_c('image-gallery',{attrs:{\"datasetId\":_vm.discoverId,\"datasetVersion\":_vm.version,\"entry\":_vm.entry,\"envVars\":_vm.envVars,\"label\":_vm.label,\"datasetThumbnail\":_vm.thumbnail,\"dataset-biolucida\":_vm.biolucidaData,\"category\":_vm.currentCategory},on:{\"card-clicked\":_vm.galleryClicked}}):_vm._e()],1),_c('div',{staticClass:\"card-right\"},[_c('div',{staticClass:\"title\",on:{\"click\":_vm.cardClicked}},[_vm._v(_vm._s(_vm.entry.name))]),_c('div',{staticClass:\"details\"},[_vm._v(_vm._s(_vm.contributors)+\" \"+_vm._s(_vm.entry.publishDate ? (\"(\" + _vm.publishYear + \")\") : ''))]),_c('div',{staticClass:\"details\"},[_vm._v(_vm._s(_vm.samples))]),(!_vm.entry.detailsReady)?_c('div',{directives:[{name:\"loading\",rawName:\"v-loading\",value:(!_vm.entry.detailsReady),expression:\"!entry.detailsReady\"}],staticClass:\"details loading-icon\"}):_vm._e(),_c('div',[(_vm.entry.simulation)?_c('el-button',{staticClass:\"button\",attrs:{\"size\":\"mini\",\"icon\":\"el-icon-view\"},on:{\"click\":_vm.openRepository}},[_vm._v(\"View repository\")]):_vm._e()],1),_c('div',{staticClass:\"badges-container\"},[_c('badges-group',{attrs:{\"entry\":_vm.entry,\"dataset-biolucida\":_vm.biolucidaData},on:{\"categoryChanged\":_vm.categoryChanged}})],1)])])])])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return (_vm.categories['All'].size > 1)?_c('div',{ref:\"container\",staticClass:\"container\"},[_c('div',[_vm._v(\" View data types: \")]),_vm._l((_vm.categories),function(item,key){return [(item.size > 0)?_c('el-button',{key:key,class:[{ 'active': key == _vm.active},'tag-button'],attrs:{\"size\":\"small\"},on:{\"click\":function($event){return _vm.categoryClicked(key)}}},[_vm._v(_vm._s(key + \" (\" + item.size + \")\")+\" \")]):_vm._e()]})],2):_vm._e()}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\r\n <div v-if=\"categories['All'].size > 1\" class=\"container\" ref=\"container\">\r\n <div>\r\n View data types:\r\n </div>\r\n <template v-for=\"(item, key) in categories\" >\r\n <el-button\r\n v-if=\"item.size > 0\"\r\n :class=\"[{ 'active': key == active},'tag-button']\"\r\n @click=\"categoryClicked(key)\"\r\n size=\"small\" :key=\"key\">{{ key + \" (\" + item.size + \")\" }}\r\n </el-button>\r\n </template>\r\n </div>\r\n</template>\r\n\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport { Button } from \"element-ui\";\r\nimport lang from \"element-ui/lib/locale/lang/en\";\r\nimport locale from \"element-ui/lib/locale\";\r\n\r\nlocale.use(lang);\r\nVue.use(Button);\r\n\r\nexport default {\r\n name: \"BadgesGroup\",\r\n props: {\r\n /**\r\n * Object containing information for\r\n * the required viewing.\r\n */\r\n additionalLinks: {\r\n type: Array,\r\n default: () => {\r\n return [];\r\n },\r\n },\r\n datasetBiolucida: {\r\n type: Object,\r\n default: () => {\r\n return {};\r\n },\r\n },\r\n entry: {\r\n type: Object,\r\n default: () => {\r\n return {};\r\n },\r\n },\r\n },\r\n data: function () {\r\n return {\r\n //Always start with 1 image - the dataset thumbnail itself\r\n categories: { \"All\": {size: 1}, \"Dataset\": {size: 1} },\r\n active: \"All\"\r\n };\r\n },\r\n methods: {\r\n addToCategories: function (array, name) {\r\n if (array && array.length > 0) {\r\n this.categories[name] = { size: array.length };\r\n this.categories[\"All\"].size += array.length;\r\n }\r\n },\r\n addSimulationsToCategories: function (array) {\r\n if (array && array.length > 0) {\r\n const size = 1;\r\n this.categories[\"Simulations\"] = { size };\r\n this.categories[\"All\"].size += size;\r\n }\r\n },\r\n categoryClicked: function(name) {\r\n this.active = name;\r\n this.$emit(\"categoryChanged\", name);\r\n }\r\n },\r\n watch: {\r\n datasetBiolucida: {\r\n deep: true,\r\n immediate: true,\r\n handler: function (biolucidaData) {\r\n if (\"dataset_images\" in biolucidaData) {\r\n this.addToCategories(biolucidaData[\"dataset_images\"], \"Images\");\r\n }\r\n }\r\n },\r\n entry: {\r\n deep: true,\r\n immediate: true,\r\n handler: function () {\r\n this.addToCategories(this.entry.scaffolds, 'Scaffolds');\r\n this.addToCategories(this.entry.segmentation, 'Segmentations');\r\n this.addToCategories(this.entry.plots, 'Plots');\r\n this.addSimulationsToCategories(this.entry.simulation);\r\n /** disable the following\r\n this.addToCategories(this.entry.images, 'Images');\r\n this.addToCategories(this.entry.videos, 'Videos');\r\n **/\r\n }\r\n }\r\n },\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/button\";\r\n\r\n.tag-button,\r\n.tag-button:hover,\r\n.tag-button:focus,\r\n.tag-button.active\r\n{\r\n border-radius: 4px;\r\n font-size: 0.75rem;\r\n padding: 0.2rem 0.2rem;\r\n margin: 0.5rem 0 0 0;\r\n margin-right: 0.75rem!important;\r\n}\r\n\r\n.tag-button,\r\n.tag-button:hover,\r\n.tag-button:focus\r\n{\r\n background: #f9f2fc;\r\n border: 1px solid $app-primary-color;\r\n color: $app-primary-color;\r\n}\r\n\r\n.tag-button.active\r\n{\r\n background: $app-primary-color;\r\n border: 1px solid $app-primary-color;\r\n color: #fff;\r\n}\r\n\r\n.tag-button+.tag-button\r\n{\r\n margin-left:0;\r\n}\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BadgesGroup.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./BadgesGroup.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./BadgesGroup.vue?vue&type=template&id=3f3b3b02&scoped=true&\"\nimport script from \"./BadgesGroup.vue?vue&type=script&lang=js&\"\nexport * from \"./BadgesGroup.vue?vue&type=script&lang=js&\"\nimport style0 from \"./BadgesGroup.vue?vue&type=style&index=0&id=3f3b3b02&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"3f3b3b02\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"full-size\"},[_c('gallery',{ref:\"gallery\",attrs:{\"bottomSpacer\":_vm.bottomSpacer,\"cardWidth\":10,\"items\":_vm.galleryItems,\"max-width\":_vm.maxWidth,\"show-indicator-bar\":false,\"show-card-details\":true,\"highlight-active\":false,\"image-style\":_vm.imageStyle,\"image-container-style\":_vm.imageContainerStyle,\"body-style\":_vm.bodyStyle,\"shadow\":_vm.shadow},on:{\"card-clicked\":_vm.cardClicked}})],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","export default function _iterableToArrayLimit(arr, i) {\n if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === \"[object Arguments]\")) {\n return;\n }\n\n var _arr = [];\n var _n = true;\n var _d = false;\n var _e = undefined;\n\n try {\n for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}","import arrayWithHoles from \"./arrayWithHoles\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit\";\nimport nonIterableRest from \"./nonIterableRest\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || nonIterableRest();\n}","<script>\r\nexport default {\r\n name: \"S3Bucket\",\r\n data() {\r\n return {\r\n s3Bucket: undefined,\r\n };\r\n },\r\n methods: {\r\n updateS3Bucket: function(s3uri) {\r\n this.s3Bucket = undefined;\r\n if (s3uri) {\r\n const substring = s3uri.split(\"//\")[1];\r\n if (substring) {\r\n this.s3Bucket = substring.split(\"/\")[0];\r\n return;\r\n }\r\n }\r\n },\r\n getS3Args: function() {\r\n if (this.s3Bucket) {\r\n return `?s3BucketName=${this.s3Bucket}`\r\n }\r\n return \"\";\r\n },\r\n },\r\n\r\n};\r\n</script>\r\n\r\n\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./S3Bucket.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./S3Bucket.vue?vue&type=script&lang=js&\"","var render, staticRenderFns\nimport script from \"./S3Bucket.vue?vue&type=script&lang=js&\"\nexport * from \"./S3Bucket.vue?vue&type=script&lang=js&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports","<template>\r\n <div class=\"full-size\">\r\n <gallery\r\n :bottomSpacer=\"bottomSpacer\"\r\n :cardWidth=\"10\"\r\n :items=\"galleryItems\"\r\n :max-width=\"maxWidth\"\r\n :show-indicator-bar=\"false\"\r\n :show-card-details=\"true\"\r\n :highlight-active=\"false\"\r\n :image-style=\"imageStyle\"\r\n :image-container-style=\"imageContainerStyle\"\r\n :body-style=\"bodyStyle\"\r\n :shadow=\"shadow\"\r\n @card-clicked=\"cardClicked\"\r\n ref=\"gallery\"\r\n />\r\n </div>\r\n</template>\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nconst baseName = (str) => {\r\n return str.split(\"\\\\\").pop().split(\"/\").pop();\r\n};\r\n\r\nconst capitalise = function (string) {\r\n return string.replace(/\\b\\w/g, (v) => v.toUpperCase());\r\n};\r\n\r\nimport GalleryHelper from \"@abi-software/gallery/src/mixins/GalleryHelpers\";\r\nimport Gallery from \"@abi-software/gallery/src/main-bundle.js\";\r\n//provide the s3Bucket related methods and data.\r\nimport S3Bucket from \"../mixins/S3Bucket\";\r\n\r\nexport default {\r\n name: \"ImageGallery\",\r\n components: { Gallery },\r\n mixins: [GalleryHelper, S3Bucket],\r\n props: {\r\n datasetBiolucida: {\r\n type: Object,\r\n default: () => {\r\n return {};\r\n },\r\n },\r\n envVars: {\r\n type: Object,\r\n default: () => {},\r\n },\r\n label: {\r\n type: String,\r\n default: \"\",\r\n },\r\n plots: {\r\n type: Array,\r\n default: () => {\r\n return [];\r\n },\r\n },\r\n datasetId: {\r\n type: Number,\r\n default: -1,\r\n },\r\n datasetVersion: {\r\n type: Number,\r\n default: -1,\r\n },\r\n datasetThumbnail: {\r\n type: String,\r\n default: \"\",\r\n },\r\n category: {\r\n type: String,\r\n default: \"All\",\r\n },\r\n entry: {\r\n type: Object,\r\n default: () => {\r\n return {};\r\n },\r\n },\r\n },\r\n data() {\r\n return {\r\n currentIndex: 0,\r\n ro: null,\r\n maxWidth: 3,\r\n items: {\r\n //Use the Images instead for Biolucida Images\r\n //\"Biolucida Images\": [],\r\n 'Dataset': [],\r\n 'Images': [],\r\n 'Scaffolds': [],\r\n 'Segmentations': [],\r\n 'Simulations': [],\r\n 'Videos': [],\r\n 'Plots': [],\r\n },\r\n bodyStyle: { padding: '0px', background: '#ffffff' },\r\n imageContainerStyle: {\r\n width: '160px',\r\n height: '160px',\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n },\r\n imageStyle: { maxWidth: '160px', maxHeight: '160px'},\r\n shadow: \"never\",\r\n bottomSpacer: { minHeight: '0rem' },\r\n resetIndex: false,\r\n };\r\n },\r\n methods: {\r\n cardClicked: function(payload) {\r\n this.$emit('card-clicked', payload);\r\n },\r\n createSciCurnchItems: function () {\r\n this.updateS3Bucket(this.entry.s3uri);\r\n this.createDatasetItem();\r\n this.createScaffoldItems();\r\n this.createSimulationItems();\r\n this.createPlotItems();\r\n this.createSegmentationItems();\r\n /* Disable these two\r\n this.createImageItems();\r\n this.createVideoItems();\r\n */\r\n },\r\n createDatasetItem: function () {\r\n const link = `${this.envVars.ROOT_URL}/datasets/${this.datasetId}?type=dataset`\r\n if (this.datasetThumbnail) {\r\n this.items['Dataset'].push({\r\n id: -1,\r\n //Work around gallery requires a truthy string\r\n title: \" \",\r\n type: `Dataset ${this.datasetId}`,\r\n thumbnail: this.datasetThumbnail,\r\n link,\r\n hideType: true,\r\n hideTitle: true,\r\n });\r\n }\r\n },\r\n createImageItems: function () {\r\n if (this.entry.images) {\r\n this.entry.images.forEach((image) => {\r\n const filePath = image.dataset.path;\r\n const id = image.identifier;\r\n const linkUrl = `${this.envVars.ROOT_URL}/datasets/imageviewer?dataset_id=${this.datasetId}&dataset_version=${this.datasetVersion}&file_path=${filePath}&mimetype=${image.mimetype.name}`;\r\n this.items['Images'].push({\r\n id,\r\n title: baseName(filePath),\r\n type: \"Image\",\r\n link: linkUrl,\r\n hideType: true,\r\n });\r\n });\r\n }\r\n },\r\n createPlotItems: function () {\r\n if (this.entry.plots) {\r\n this.entry.plots.forEach((plot) => {\r\n const filePath = plot.dataset.path;\r\n const id = plot.identifier;\r\n const thumbnail = this.getThumbnailForPlot(plot, this.entry.thumbnails);\r\n let thumbnailURL = undefined;\r\n let mimetype = '';\r\n if (thumbnail) {\r\n thumbnailURL = this.getImageURLFromS3(this.envVars.API_LOCATION, {\r\n id,\r\n datasetId: this.datasetId,\r\n datasetVersion: this.datasetVersion,\r\n file_path: thumbnail.dataset.path,\r\n s3Bucket: this.s3Bucket,\r\n });\r\n mimetype = thumbnail.mimetype.name;\r\n }\r\n const plotAnnotation = plot.datacite;\r\n const filePathPrefix = `${this.envVars.API_LOCATION}/s3-resource/${this.datasetId}/${this.datasetVersion}/files/`;\r\n const sourceUrl = filePathPrefix + plot.dataset.path + this.getS3Args();\r\n\r\n //plotAnnotation.supplemental_json_metadata.description can be undefined or\r\n //contain an empty string causing an error with JSON.parse\r\n let metadata = {};\r\n try { \r\n metadata = JSON.parse(\r\n plotAnnotation.supplemental_json_metadata.description\r\n );\r\n } catch (error) {\r\n console.warn(error);\r\n }\r\n\r\n let supplementalData = [];\r\n if (plotAnnotation.isDescribedBy) {\r\n supplementalData.push({\r\n url: filePathPrefix + plotAnnotation.isDescribedBy.path\r\n });\r\n }\r\n\r\n const resource = {\r\n dataSource: {url: sourceUrl},\r\n metadata,\r\n supplementalData\r\n }\r\n\r\n let action = {\r\n label: capitalise(this.label),\r\n resource: resource,\r\n s3uri: this.entry.s3uri,\r\n title: \"View plot\",\r\n type: \"Plot\",\r\n discoverId: this.discoverId,\r\n version: this.datasetVersion,\r\n };\r\n this.items['Plots'].push({\r\n id,\r\n title: baseName(filePath),\r\n type: \"Plot\",\r\n thumbnail: thumbnailURL,\r\n userData: action,\r\n hideType: true,\r\n mimetype\r\n });\r\n });\r\n }\r\n },\r\n createScaffoldItems: function () {\r\n if (this.entry.scaffolds) {\r\n let index = 0;\r\n this.entry.scaffolds.forEach((scaffold, i) => {\r\n const filePath = scaffold.dataset.path;\r\n const id = scaffold.identifier;\r\n const thumbnail = this.getThumbnailForScaffold(\r\n scaffold,\r\n this.entry.scaffoldViews,\r\n this.entry.thumbnails,\r\n index\r\n );\r\n let mimetype = '';\r\n let thumbnailURL = undefined;\r\n if (thumbnail) {\r\n thumbnailURL = this.getImageURLFromS3(this.envVars.API_LOCATION, {\r\n id,\r\n datasetId: this.datasetId,\r\n datasetVersion: this.datasetVersion,\r\n file_path: thumbnail.dataset.path,\r\n s3Bucket: this.s3Bucket,\r\n });\r\n mimetype = thumbnail.mimetype.name;\r\n }\r\n let action = {\r\n label: capitalise(this.label),\r\n resource: `${this.envVars.API_LOCATION}s3-resource/${this.datasetId}/${this.datasetVersion}/files/${filePath}${this.getS3Args()}`,\r\n title: \"View 3D scaffold\",\r\n type: \"Scaffold\",\r\n discoverId: this.datasetId,\r\n apiLocation: this.envVars.API_LOCATION,\r\n version: this.datasetVersion,\r\n banner: this.datasetThumbnail,\r\n s3uri: this.entry.s3uri,\r\n contextCardUrl: this.getContextCardUrl(i)\r\n };\r\n this.items['Scaffolds'].push({\r\n id,\r\n title: baseName(filePath),\r\n type: \"Scaffold\",\r\n thumbnail: thumbnailURL,\r\n userData: action,\r\n hideType: true,\r\n mimetype\r\n });\r\n });\r\n }\r\n },\r\n createSegmentationItems: function () {\r\n if (this.entry.segmentation) {\r\n this.entry.segmentation.forEach((segmentation) => {\r\n const id = segmentation.id;\r\n let filePath = segmentation.dataset.path;\r\n filePath = filePath.replaceAll(\" \", \"_\");\r\n filePath = filePath.replaceAll(\",\", \"_\");\r\n const prefix = this.envVars.NL_LINK_PREFIX;\r\n const resource = {\r\n share_link: `${prefix}/dataviewer?datasetId=${this.datasetId}&version=${this.datasetVersion}&path=files/${filePath}`,\r\n };\r\n let action = {\r\n label: capitalise(this.label),\r\n resource: resource,\r\n datasetId: this.datasetId,\r\n s3uri: this.entry.s3uri,\r\n title: \"View segmentation\",\r\n type: \"Segmentation\",\r\n };\r\n const thumbnailURL = this.getSegmentationThumbnailURL(\r\n this.envVars.API_LOCATION,\r\n {\r\n id,\r\n datasetId: this.datasetId,\r\n datasetVersion: this.datasetVersion,\r\n segmentationFilePath: filePath,\r\n s3Bucket: this.s3Bucket,\r\n }\r\n );\r\n this.items['Segmentations'].push({\r\n id,\r\n title: baseName(filePath),\r\n type: \"Segmentation\",\r\n thumbnail: thumbnailURL,\r\n userData: action,\r\n hideType: true,\r\n mimetype: 'image/png',\r\n });\r\n });\r\n }\r\n },\r\n createSimulationItems: function () {\r\n if (this.entry.simulation && this.entry.simulation.length > 0) {\r\n let action = {\r\n label: undefined,\r\n apiLocation: this.envVars.API_LOCATION,\r\n s3uri: this.entry.s3uri,\r\n version: this.datasetVersion,\r\n title: \"View simulation\",\r\n type: \"Simulation\",\r\n name: this.entry.name,\r\n description: this.entry.description,\r\n discoverId: this.datasetId,\r\n dataset: `${this.envVars.ROOT_URL}/datasets/${this.datasetId}?type=dataset`\r\n };\r\n this.items['Simulations'].push({\r\n id: \"simulation\",\r\n title: \" \",\r\n type: \"Simulation\",\r\n hideType: true,\r\n hideTitle: true,\r\n userData: action,\r\n });\r\n }\r\n },\r\n createVideoItems: function () {\r\n if (this.entry.videos) {\r\n this.entry.videos.forEach((video) => {\r\n const filePath = this.getS3FilePath(\r\n this.datasetId,\r\n this.datasetVersion,\r\n video.dataset.path\r\n );\r\n const linkUrl = `${this.envVars.ROOT_URL}/datasets/videoviewer?dataset_version=${this.datasetVersion}&dataset_id=${this.datasetId}&file_path=${filePath}&mimetype=${video.mimetype.name}`;\r\n this.items['Videos'].push({\r\n title: video.name,\r\n type: \"Video\",\r\n thumbnail: this.defaultVideoImg,\r\n hideType: true,\r\n link: linkUrl,\r\n });\r\n });\r\n }\r\n },\r\n onResize: function () {\r\n this.maxWidth = this.$el.clientWidth;\r\n // this.$emit('resize', this.$el.clientWidth)\r\n },\r\n getContextCardUrl(scaffoldIndex){\r\n if(!this.entry.contextualInformation || this.entry.contextualInformation.length == 0){\r\n return undefined\r\n } else {\r\n // The line below checks if there is a context file for each scaffold. If there is not, we use the first context card for each scaffold.\r\n let contextIndex = this.entry['abi-contextual-information'].length == this.entry.scaffolds.length ? scaffoldIndex : 0\r\n return `${this.envVars.API_LOCATION}s3-resource/${this.datasetId}/${this.datasetVersion}/files/${this.entry.contextualInformation[contextIndex]}${this.getS3Args()}`\r\n }\r\n }\r\n },\r\n computed: {\r\n galleryItems() {\r\n if (this.resetIndex) {\r\n this.$refs.gallery.indicatorClicked(0);\r\n }\r\n let items = [...this.items[\"Dataset\"]];\r\n if (this.category === \"All\") {\r\n for (const [key, value] of Object.entries(this.items)) {\r\n if (key !== \"Dataset\")\r\n items = items.concat(value);\r\n }\r\n return items;\r\n }\r\n else\r\n return this.items[this.category];\r\n },\r\n },\r\n created: function () {\r\n this.createSciCurnchItems();\r\n },\r\n watch: {\r\n category: function() {\r\n this.resetIndex = true;\r\n },\r\n galleryItems: function() {\r\n this.resetIndex = false;\r\n },\r\n datasetBiolucida: {\r\n deep: true,\r\n immediate: true,\r\n handler: function (biolucidaData) {\r\n let items = [];\r\n if (\"dataset_images\" in biolucidaData) {\r\n items.push(\r\n ...Array.from(biolucidaData.dataset_images, (dataset_image) => {\r\n const thumbnailURL = this.getThumbnailURLFromBiolucida(\r\n this.envVars.API_LOCATION,\r\n {\r\n id: dataset_image.image_id,\r\n }\r\n );\r\n const resource = {\r\n share_link: dataset_image.share_link,\r\n id: dataset_image.image_id,\r\n itemId: dataset_image.sourcepkg_id,\r\n };\r\n let action = {\r\n label: capitalise(this.label),\r\n resource: resource,\r\n datasetId: this.datasetId,\r\n title: \"View image\",\r\n name: capitalise(this.label),\r\n type: \"Biolucida\",\r\n };\r\n return {\r\n id: dataset_image.image_id,\r\n title: `Image`,\r\n type: \"Image\",\r\n thumbnail: thumbnailURL,\r\n userData: action,\r\n mimetype: 'image/png',\r\n hideType: true,\r\n };\r\n })\r\n );\r\n }\r\n this.items['Images'] = items;\r\n },\r\n },\r\n },\r\n mounted() {\r\n this.ro = new ResizeObserver(this.onResize).observe(this.$el);\r\n },\r\n destroyed() {\r\n delete this.ro;\r\n },\r\n};\r\n</script>\r\n\r\n<style scoped lang=\"scss\">\r\n.full-size {\r\n height: 100%;\r\n width: 244px;\r\n}\r\n\r\n.key-image-span.active {\r\n transform: scale(1.16);\r\n border: 4px $app-primary-color solid;\r\n}\r\n\r\n.key-image-span {\r\n display: flex;\r\n position: relative;\r\n}\r\n\r\n.overlay {\r\n position: absolute;\r\n right: 5px;\r\n top: 5px;\r\n width: 1.61em;\r\n height: 1em;\r\n border-radius: 3px;\r\n opacity: 0.8;\r\n}\r\n\r\nimg {\r\n vertical-align: bottom;\r\n}\r\n\r\na.prev,\r\na.next {\r\n display: flex;\r\n font-size: 3em;\r\n}\r\n\r\na.prev:not(.underline),\r\na.next:not(.underline) {\r\n text-decoration: none;\r\n}\r\n\r\na.prev {\r\n justify-content: flex-start;\r\n}\r\n\r\na.next {\r\n justify-content: flex-end;\r\n}\r\n\r\n.standard-gallery {\r\n display: flex;\r\n flex-wrap: nowrap;\r\n justify-content: space-around;\r\n align-items: center;\r\n}\r\n\r\n.image-line {\r\n display: flex;\r\n margin-top: 1%;\r\n margin-bottom: 1%;\r\n flex-grow: 1;\r\n justify-content: space-between;\r\n}\r\n.disabled {\r\n opacity: 0.2;\r\n cursor: default;\r\n}\r\n\r\n.rectangle {\r\n height: 1em;\r\n width: 2em;\r\n border-radius: 3px;\r\n background-color: #555;\r\n}\r\n\r\n.full-size ::v-deep .el-card {\r\n border: 0px;\r\n}\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ImageGallery.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ImageGallery.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./ImageGallery.vue?vue&type=template&id=31f0d189&scoped=true&\"\nimport script from \"./ImageGallery.vue?vue&type=script&lang=js&\"\nexport * from \"./ImageGallery.vue?vue&type=script&lang=js&\"\nimport style0 from \"./ImageGallery.vue?vue&type=style&index=0&id=31f0d189&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"31f0d189\",\n null\n \n)\n\nexport default component.exports","<template>\r\n <div class=\"dataset-card-container\" ref=\"container\">\r\n <div class=\"dataset-card\" ref=\"card\">\r\n <div class=\"seperator-path\"></div>\r\n <div v-loading=\"loading\" class=\"card\" >\r\n <span class=\"card-left\">\r\n <image-gallery v-if=\"!loading && discoverId\" \r\n :datasetId=\"discoverId\"\r\n :datasetVersion=\"version\"\r\n :entry=\"entry\"\r\n :envVars=\"envVars\"\r\n :label=\"label\"\r\n :datasetThumbnail=\"thumbnail\"\r\n :dataset-biolucida=\"biolucidaData\"\r\n :category=\"currentCategory\"\r\n @card-clicked=\"galleryClicked\"\r\n />\r\n </span>\r\n <div class=\"card-right\" >\r\n <div class=\"title\" @click=\"cardClicked\">{{entry.name}}</div>\r\n <div class=\"details\">{{contributors}} {{entry.publishDate ? `(${publishYear})` : ''}}</div>\r\n <div class=\"details\">{{samples}}</div>\r\n <div v-if=\"!entry.detailsReady\" class=\"details loading-icon\" v-loading=\"!entry.detailsReady\"></div>\r\n <div>\r\n <el-button v-if=\"entry.simulation\" @click=\"openRepository\" size=\"mini\" class=\"button\" icon=\"el-icon-view\">View repository</el-button>\r\n </div>\r\n <div class=\"badges-container\">\r\n <badges-group\r\n :entry=\"entry\"\r\n :dataset-biolucida=\"biolucidaData\"\r\n @categoryChanged=\"categoryChanged\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport BadgesGroup from \"./BadgesGroup.vue\";\r\nimport { Button, Icon } from \"element-ui\";\r\nimport lang from \"element-ui/lib/locale/lang/en\";\r\nimport locale from \"element-ui/lib/locale\";\r\nimport EventBus from \"./EventBus\"\r\nimport speciesMap from \"./species-map\";\r\nimport ImageGallery from \"./ImageGallery.vue\";\r\n\r\nlocale.use(lang);\r\nVue.use(Button);\r\nVue.use(Icon);\r\n\r\nexport default {\r\n name: \"DatasetCard\",\r\n components: { BadgesGroup, ImageGallery },\r\n props: {\r\n /**\r\n * Object containing information for\r\n * the required viewing.\r\n */\r\n entry: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n envVars: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n },\r\n data: function () {\r\n return {\r\n thumbnail: require('@/../assets/missing-image.svg'),\r\n dataLocation: this.entry.doi,\r\n discoverId: undefined,\r\n loading: true,\r\n version: 1,\r\n lastDoi: undefined,\r\n biolucidaData: undefined,\r\n currentCategory: \"All\"\r\n };\r\n },\r\n computed: {\r\n contributors: function() {\r\n let text = \"\";\r\n if (this.entry.contributors) {\r\n if (this.entry.contributors.length === 1) {\r\n text = this.lastName(this.entry.contributors[0].name);\r\n } else if (this.entry.contributors.length === 2) {\r\n text = this.lastName(this.entry.contributors[0].name) + \" & \" + this.lastName(this.entry.contributors[1].name);\r\n } else if (this.entry.contributors.length > 2) {\r\n text = this.lastName(this.entry.contributors[0].name) + \" et al.\";\r\n }\r\n }\r\n return text;\r\n },\r\n samples: function() {\r\n let text = \"\";\r\n if (this.entry.species) {\r\n if (speciesMap[this.entry.species[0].toLowerCase()]){\r\n text = `${speciesMap[this.entry.species[0].toLowerCase()]}`;\r\n } else {\r\n text = `${this.entry.species}`;\r\n }\r\n }\r\n if (this.entry.numberSamples > 0) {\r\n text += \" (\";\r\n if (this.entry.numberSamples === 1) {\r\n text += `${this.entry.numberSamples} sample`;\r\n } else if (this.entry.numberSamples > 1) {\r\n text += `${this.entry.numberSamples} samples`;\r\n }\r\n if (this.entry.numberSubjects === 1) {\r\n text += ` from ${this.entry.numberSubjects} subject`;\r\n } else if (this.entry.numberSamples > 1) {\r\n text += ` from ${this.entry.numberSubjects} subjects`;\r\n }\r\n text += \")\";\r\n }\r\n\r\n return text;\r\n },\r\n label: function(){\r\n return this.entry.organs ? this.entry.organs[0] : this.entry.name\r\n },\r\n publishYear: function() {\r\n return this.entry.publishDate.split('-')[0]\r\n }\r\n },\r\n methods: {\r\n cardClicked: function(){\r\n this.openDataset()\r\n },\r\n categoryChanged: function(name) {\r\n this.currentCategory = name;\r\n },\r\n galleryClicked: function(payload) {\r\n this.propogateCardAction(payload)\r\n },\r\n openDataset: function(){\r\n window.open(this.dataLocation,'_blank');\r\n },\r\n openRepository: function() {\r\n let apiLocation = this.envVars.API_LOCATION;\r\n this.entry.additionalLinks.forEach(function(el) {\r\n if (el.description == \"Repository\") {\r\n let xmlhttp = new XMLHttpRequest();\r\n xmlhttp.open(\"POST\", apiLocation + \"/pmr_latest_exposure\", true);\r\n xmlhttp.setRequestHeader(\"Content-type\", \"application/json\");\r\n xmlhttp.onreadystatechange = () => {\r\n if (xmlhttp.readyState === 4) {\r\n let url = \"\";\r\n if (xmlhttp.status === 200) {\r\n url = JSON.parse(xmlhttp.responseText)[\"url\"];\r\n }\r\n if (url === \"\") {\r\n url = el.uri;\r\n }\r\n window.open(url,'_blank');\r\n }\r\n };\r\n xmlhttp.send(JSON.stringify({workspace_url: el.uri}));\r\n }\r\n });\r\n },\r\n propogateCardAction: function(action){\r\n EventBus.$emit(\"PopoverActionClick\", action)\r\n EventBus.$emit(\"contextUpdate\", action) // Pass to mapintegratedvuer\r\n },\r\n splitDOI: function(doi){\r\n return [doi.split('/')[doi.split('/').length-2], doi.split('/')[doi.split('/').length-1]]\r\n },\r\n getBanner: function () {\r\n // Only load banner if card has changed\r\n if (this.lastDoi !== this.entry.doi) {\r\n this.lastDoi = this.entry.doi\r\n this.loading = true\r\n let doi = this.splitDOI(this.entry.doi)\r\n fetch(`${this.envVars.PENNSIEVE_API_LOCATION}/discover/datasets/doi/${doi[0]}/${doi[1]}`)\r\n .then((response) =>{\r\n if (!response.ok){\r\n throw Error(response.statusText)\r\n } else {\r\n return response.json()\r\n }\r\n })\r\n .then((data) => {\r\n this.thumbnail = data.banner\r\n this.discoverId = data.id\r\n this.version = data.version\r\n this.dataLocation = `https://sparc.science/datasets/${data.id}?type=dataset`\r\n this.getBiolucidaInfo(this.discoverId)\r\n this.loading = false\r\n })\r\n .catch(() => {\r\n //set defaults if we hit an error\r\n this.thumbnail = require('@/../assets/missing-image.svg')\r\n this.discoverId = Number(this.entry.datasetId)\r\n this.loading = false\r\n });\r\n }\r\n\r\n },\r\n lastName: function(fullName){\r\n return fullName.split(',')[0]\r\n },\r\n getBiolucidaInfo: function(id) {\r\n let apiLocation = this.envVars.API_LOCATION;\r\n let endpoint = apiLocation + \"image_search/\" + id;\r\n // Add parameters if we are sent them\r\n fetch(endpoint)\r\n .then(response => response.json())\r\n .then(data => {\r\n if (data.status == \"success\")\r\n this.biolucidaData = data;\r\n });\r\n }\r\n },\r\n created: function() {\r\n this.getBanner()\r\n },\r\n watch: {\r\n // currently not using card overflow\r\n 'entry.description': function() { // watch it\r\n this.getBanner()\r\n }\r\n },\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/col\";\r\n@import \"~element-ui/packages/theme-chalk/src/loading\";\r\n\r\n.dataset-card {\r\n padding-left: 16px;\r\n position: relative;\r\n min-height:17rem;\r\n}\r\n\r\n.title {\r\n padding-bottom: 0.75rem;\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-weight: bold;\r\n font-stretch: normal;\r\n font-style: normal;\r\n line-height: 1.5;\r\n letter-spacing: 1.05px;\r\n color: #484848;\r\n cursor: pointer;\r\n}\r\n.card {\r\n padding-top: 18px;\r\n position: relative;\r\n display: flex;\r\n}\r\n\r\n.card-left{\r\n flex: 1\r\n}\r\n\r\n.card-right {\r\n flex: 1.3;\r\n padding-left: 6px;\r\n}\r\n\r\n.button{\r\n z-index: 10;\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-weight: normal;\r\n font-stretch: normal;\r\n font-style: normal;\r\n line-height: normal;\r\n letter-spacing: normal;\r\n background-color: $app-primary-color;\r\n border: $app-primary-color;\r\n color: white;\r\n cursor: pointer;\r\n margin-top: 8px;\r\n}\r\n\r\n.button:hover {\r\n background-color: $app-primary-color;\r\n color: white;\r\n}\r\n\r\n.banner-img {\r\n width: 128px;\r\n height: 128px;\r\n box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.25);\r\n background-color: #ffffff;\r\n cursor: pointer;\r\n}\r\n.details{\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-weight: normal;\r\n font-stretch: normal;\r\n font-style: normal;\r\n line-height: 1.5;\r\n letter-spacing: 1.05px;\r\n color: #484848;\r\n}\r\n\r\n.badges-container {\r\n margin-top:0.75rem;\r\n}\r\n\r\n.loading-icon {\r\n z-index: 20;\r\n width: 40px;\r\n height: 40px;\r\n left: 80px;\r\n}\r\n\r\n.loading-icon ::v-deep .el-loading-mask {\r\n background-color: rgba(117, 190, 218, 0.0) !important;\r\n}\r\n\r\n.loading-icon ::v-deep .el-loading-spinner .path {\r\n stroke: $app-primary-color;\r\n}\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./DatasetCard.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./DatasetCard.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./DatasetCard.vue?vue&type=template&id=b08ebd76&scoped=true&\"\nimport script from \"./DatasetCard.vue?vue&type=script&lang=js&\"\nexport * from \"./DatasetCard.vue?vue&type=script&lang=js&\"\nimport style0 from \"./DatasetCard.vue?vue&type=style&index=0&id=b08ebd76&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"b08ebd76\",\n null\n \n)\n\nexport default component.exports","<template>\r\n <el-card :body-style=\"bodyStyle\" class=\"content-card\">\r\n <div slot=\"header\" class=\"header\">\r\n <el-input\r\n class=\"search-input\"\r\n placeholder=\"Search\"\r\n v-model=\"searchInput\"\r\n @keyup.native=\"searchEvent\"\r\n clearable\r\n @clear=\"clearSearchClicked\"\r\n ></el-input>\r\n <el-button class=\"button\" @click=\"searchEvent\">Search</el-button>\r\n </div>\r\n <SearchFilters\r\n class=\"filters\"\r\n ref=\"filtersRef\"\r\n :entry=\"filterEntry\"\r\n :envVars=\"envVars\"\r\n @filterResults=\"filterUpdate\"\r\n @numberPerPage=\"numberPerPageUpdate\"\r\n @loading=\"filtersLoading\"\r\n @cascaderReady=\"cascaderReady\"\r\n ></SearchFilters>\r\n <search-history ref=\"searchHistory\" @search=\"searchHistorySearch\"></search-history>\r\n <div class=\"content scrollbar\" v-loading=\"loadingCards\" ref=\"content\">\r\n <div class=\"error-feedback\" v-if=\"results.length === 0 && !loadingCards\">\r\n No results found - Please change your search / filter criteria.\r\n </div>\r\n <div v-for=\"result in results\" :key=\"result.doi\" class=\"step-item\">\r\n <DatasetCard\r\n :entry=\"result\"\r\n :envVars=\"envVars\"\r\n ></DatasetCard>\r\n </div>\r\n <el-pagination\r\n class=\"pagination\"\r\n :current-page.sync=\"page\"\r\n hide-on-single-page\r\n large\r\n layout=\"prev, pager, next\"\r\n :page-size=\"numberPerPage\"\r\n :total=\"numberOfHits\"\r\n @current-change=\"pageChange\"\r\n ></el-pagination>\r\n </div>\r\n </el-card>\r\n</template>\r\n\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport {\r\n Button,\r\n Card,\r\n Drawer,\r\n Icon,\r\n Input,\r\n Loading,\r\n Pagination,\r\n} from \"element-ui\";\r\nimport lang from \"element-ui/lib/locale/lang/en\";\r\nimport locale from \"element-ui/lib/locale\";\r\nimport SearchFilters from \"./SearchFilters\";\r\nimport SearchHistory from \"./SearchHistory\";\r\nimport DatasetCard from \"./DatasetCard\";\r\nimport EventBus from \"./EventBus\";\r\n\r\nimport { AlgoliaClient } from \"../algolia/algolia.js\";\r\nimport { getFilters, facetPropPathMapping } from \"../algolia/utils.js\";\r\n\r\nlocale.use(lang);\r\nVue.use(Button);\r\nVue.use(Card);\r\nVue.use(Drawer);\r\nVue.use(Icon);\r\nVue.use(Input);\r\nVue.use(Loading);\r\nVue.use(Pagination);\r\n\r\n// handleErrors: A custom fetch error handler to recieve messages from the server\r\n// even when an error is found\r\nvar handleErrors = async function (response) {\r\n if (!response.ok) {\r\n let parse = await response.json();\r\n if (parse) {\r\n throw new Error(parse.message);\r\n } else {\r\n throw new Error(response);\r\n }\r\n }\r\n return response;\r\n};\r\n\r\nvar initial_state = {\r\n searchInput: \"\",\r\n lastSearch: \"\",\r\n results: [],\r\n numberOfHits: 0,\r\n filter: [],\r\n loadingCards: false,\r\n numberPerPage: 10,\r\n page: 1,\r\n pageModel: 1,\r\n start: 0,\r\n hasSearched: false,\r\n contextCardEnabled: false,\r\n};\r\n\r\nexport default {\r\n components: { SearchFilters, DatasetCard, SearchHistory },\r\n name: \"SideBarContent\",\r\n props: {\r\n visible: {\r\n type: Boolean,\r\n default: false,\r\n },\r\n isDrawer: {\r\n type: Boolean,\r\n default: true,\r\n },\r\n entry: {\r\n type: Object,\r\n default: () => initial_state,\r\n },\r\n envVars: {\r\n type: Object,\r\n default: () => {},\r\n },\r\n },\r\n data: function () {\r\n return {\r\n ...this.entry,\r\n bodyStyle: {\r\n flex: \"1 1 auto\",\r\n \"flex-flow\": \"column\",\r\n display: \"flex\",\r\n },\r\n cascaderIsReady: false,\r\n };\r\n },\r\n computed: {\r\n // This computed property populates filter data's entry object with $data from this sidebar\r\n filterEntry: function () {\r\n return {\r\n numberOfHits: this.numberOfHits,\r\n filterFacets: this.filter,\r\n };\r\n },\r\n },\r\n methods: {\r\n resetSearch: function () {\r\n this.numberOfHits = 0;\r\n this.discoverIds = [];\r\n this._dois = [];\r\n this.results = [];\r\n this.loadingCards = false;\r\n },\r\n openSearch: function (filter, search = \"\") {\r\n this.searchInput = search;\r\n this.resetPageNavigation();\r\n //Proceed normally if cascader is ready\r\n if (this.cascaderIsReady) {\r\n this.filter = this.$refs.filtersRef.getValidatedFilters(filter);\r\n //Facets provided but cannot find at least one valid\r\n //facet. Tell the users the search is invalid and reset\r\n //facets check boxes.\r\n if (\r\n filter &&\r\n filter.length > 0 &&\r\n this.filter &&\r\n this.filter.length === 0\r\n ) {\r\n this.$refs.filtersRef.checkShowAllBoxes();\r\n this.resetSearch();\r\n } else if (this.filter) {\r\n this.searchAlgolia(this.filter, search);\r\n this.$refs.filtersRef.setCascader(this.filter);\r\n }\r\n } else {\r\n //cascader is not ready, perform search if no filter is set,\r\n //otherwise waith for cascader to be ready\r\n this.filter = filter;\r\n if (!filter || filter.length == 0) {\r\n this.searchAlgolia(this.filter, search);\r\n }\r\n }\r\n },\r\n addFilter: function (filter) {\r\n if (this.cascaderIsReady) {\r\n this.resetPageNavigation();\r\n if (filter) {\r\n if (this.$refs.filtersRef.addFilter(filter))\r\n this.$refs.filtersRef.initiateSearch();\r\n }\r\n } else {\r\n if (Array.isArray(this.filter)) {\r\n this.filter.push(filter);\r\n } else {\r\n this.filter = [filter];\r\n }\r\n }\r\n },\r\n cascaderReady: function () {\r\n this.cascaderIsReady = true;\r\n this.openSearch(this.filter, this.searchInput);\r\n },\r\n clearSearchClicked: function () {\r\n this.searchInput = \"\";\r\n this.resetPageNavigation();\r\n this.searchAlgolia(this.filters, this.searchInput);\r\n this.$refs.searchHistory.selectValue = 'Full search history'\r\n },\r\n searchEvent: function (event = false) {\r\n if (event.keyCode === 13 || event instanceof MouseEvent) {\r\n this.resetPageNavigation();\r\n this.searchAlgolia(this.filters, this.searchInput);\r\n this.$refs.searchHistory.selectValue = 'Full search history'\r\n this.$refs.searchHistory.addSearchToHistory(this.filters, this.searchInput);\r\n }\r\n },\r\n filterUpdate: function (filters) {\r\n this.filters = [...filters];\r\n this.resetPageNavigation();\r\n this.searchAlgolia(filters, this.searchInput);\r\n this.$emit(\"search-changed\", {\r\n value: filters,\r\n type: \"filter-update\",\r\n });\r\n },\r\n searchAlgolia(filters, query = \"\") {\r\n // Algolia search\r\n this.loadingCards = true;\r\n this.algoliaClient\r\n .anatomyInSearch(getFilters(filters), query)\r\n .then((anatomy) => {\r\n EventBus.$emit(\"available-facets\", {\r\n 'uberons': anatomy,\r\n 'labels': this.algoliaClient.anatomyFacetLabels\r\n });\r\n });\r\n this.algoliaClient\r\n .search(getFilters(filters), query, this.numberPerPage, this.page)\r\n .then((searchData) => {\r\n this.numberOfHits = searchData.total;\r\n this.discoverIds = searchData.discoverIds;\r\n this._dois = searchData.dois;\r\n this.results = searchData.items;\r\n this.loadingCards = false;\r\n this.scrollToTop();\r\n this.$emit(\"search-changed\", {\r\n value: this.searchInput,\r\n type: \"query-update\",\r\n });\r\n if (this._abortController) this._abortController.abort();\r\n this._abortController = new AbortController();\r\n const signal = this._abortController.signal;\r\n //Search ongoing, let the current flow progress\r\n this.perItemSearch(signal, { count: 0 });\r\n });\r\n },\r\n filtersLoading: function (val) {\r\n this.loadingCards = val;\r\n },\r\n numberPerPageUpdate: function (val) {\r\n this.numberPerPage = val;\r\n this.pageChange(1);\r\n },\r\n pageChange: function (page) {\r\n this.start = (page - 1) * this.numberPerPage;\r\n this.page = page;\r\n this.searchAlgolia(\r\n this.filters,\r\n this.searchInput,\r\n this.numberPerPage,\r\n this.page\r\n );\r\n },\r\n handleMissingData: function (doi) {\r\n let i = this.results.findIndex((res) => res.doi === doi);\r\n if (this.results[i]) this.results[i].detailsReady = true;\r\n },\r\n perItemSearch: function (signal, data) {\r\n //Maximum 10 downloads at once to prevent long waiting time\r\n //between unfinished search and new search\r\n const maxDownloads = 10;\r\n if (maxDownloads > data.count) {\r\n const doi = this._dois.shift();\r\n if (doi) {\r\n data.count++;\r\n this.callSciCrunch(this.envVars.API_LOCATION, { dois: [doi] }, signal)\r\n .then((result) => {\r\n if (result.numberOfHits === 0) this.handleMissingData(doi);\r\n else this.resultsProcessing(result);\r\n this.$refs.content.style[\"overflow-y\"] = \"scroll\";\r\n data.count--;\r\n //Async::Download finished, get the next one\r\n this.perItemSearch(signal, data);\r\n })\r\n .catch((result) => {\r\n if (result.name !== \"AbortError\") {\r\n this.handleMissingData(doi);\r\n data.count--;\r\n //Async::Download not aborted, get the next one\r\n this.perItemSearch(signal, data);\r\n }\r\n });\r\n //Check and make another request until it gets to max downloads\r\n this.perItemSearch(signal, data);\r\n }\r\n }\r\n },\r\n scrollToTop: function () {\r\n if (this.$refs.content) {\r\n this.$refs.content.scroll({ top: 0, behavior: \"smooth\" });\r\n }\r\n },\r\n resetPageNavigation: function () {\r\n this.start = 0;\r\n this.page = 1;\r\n },\r\n resultsProcessing: function (data) {\r\n this.lastSearch = this.searchInput;\r\n\r\n if (data.results.length === 0) {\r\n return;\r\n }\r\n data.results.forEach((element) => {\r\n // match the scicrunch result with algolia result\r\n let i = this.results.findIndex((res) =>\r\n element.doi ? element.doi.includes(res.doi) : false\r\n );\r\n // Assign scicrunch results to the object\r\n Object.assign(this.results[i], element);\r\n // Assign the attributes that need some processing\r\n Object.assign(this.results[i], {\r\n numberSamples: element.sampleSize ? parseInt(element.sampleSize) : 0,\r\n numberSubjects: element.subjectSize\r\n ? parseInt(element.subjectSize)\r\n : 0,\r\n updated:\r\n (element.updated && element.updated.length) > 0\r\n ? element.updated[0].timestamp.split(\"T\")[0]\r\n : \"\",\r\n url: element.uri[0],\r\n datasetId: element.dataset_identifier,\r\n datasetRevision: element.dataset_revision,\r\n datasetVersion: element.dataset_version,\r\n organs:\r\n element.organs && element.organs.length > 0\r\n ? [...new Set(element.organs.map((v) => v.name))]\r\n : undefined,\r\n species: element.organisms\r\n ? element.organisms[0].species\r\n ? [\r\n ...new Set(\r\n element.organisms.map((v) =>\r\n v.species ? v.species.name : null\r\n )\r\n ),\r\n ]\r\n : undefined\r\n : undefined, // This processing only includes each gender once into 'sexes'\r\n scaffolds: element[\"abi-scaffold-metadata-file\"],\r\n thumbnails: element[\"abi-thumbnail\"]\r\n ? element[\"abi-thumbnail\"]\r\n : element[\"abi-scaffold-thumbnail\"],\r\n scaffoldViews: element[\"abi-scaffold-view-file\"],\r\n videos: element.video,\r\n plots: element[\"abi-plot\"],\r\n images: element[\"common-images\"],\r\n contextualInformation:\r\n element[\"abi-contextual-information\"].length > 0\r\n ? element[\"abi-contextual-information\"]\r\n : undefined,\r\n segmentation: element[\"mbf-segmentation\"],\r\n simulation: element[\"abi-simulation-file\"],\r\n additionalLinks: element.additionalLinks,\r\n detailsReady: true,\r\n });\r\n Vue.set(this.results, i, this.results[i]);\r\n });\r\n },\r\n createfilterParams: function (params) {\r\n let p = new URLSearchParams();\r\n //Check if field is array or value\r\n for (const key in params) {\r\n if (Array.isArray(params[key])) {\r\n params[key].forEach((e) => {\r\n p.append(key, e);\r\n });\r\n } else {\r\n p.append(key, params[key]);\r\n }\r\n }\r\n return p.toString();\r\n },\r\n callSciCrunch: function (apiLocation, params = {}, signal) {\r\n return new Promise((resolve, reject) => {\r\n // Add parameters if we are sent them\r\n let fullEndpoint =\r\n this.envVars.API_LOCATION +\r\n this.searchEndpoint +\r\n \"?\" +\r\n this.createfilterParams(params);\r\n fetch(fullEndpoint, { signal })\r\n .then(handleErrors)\r\n .then((response) => response.json())\r\n .then((data) => resolve(data))\r\n .catch((data) => reject(data));\r\n });\r\n },\r\n getAlgoliaFacets: async function(){\r\n let facets = await this.algoliaClient.getAlgoliaFacets(facetPropPathMapping)\r\n return facets;\r\n },\r\n searchHistorySearch: function(item){\r\n this.searchInput = item.search;\r\n this.filters = item.filters;\r\n this.openSearch(item.filters, item.search);\r\n }\r\n },\r\n mounted: function () {\r\n // initialise algolia\r\n this.algoliaClient = new AlgoliaClient(\r\n this.envVars.ALGOLIA_ID,\r\n this.envVars.ALGOLIA_KEY,\r\n this.envVars.PENNSIEVE_API_LOCATION\r\n );\r\n this.algoliaClient.initIndex(this.envVars.ALGOLIA_INDEX);\r\n this.openSearch(this.filter, this.searchInput);\r\n },\r\n created: function () {\r\n //Create non-reactive local variables\r\n this.searchEndpoint = \"dataset_info/using_multiple_dois/\";\r\n },\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/button\";\r\n@import \"~element-ui/packages/theme-chalk/src/card\";\r\n@import \"~element-ui/packages/theme-chalk/src/drawer\";\r\n@import \"~element-ui/packages/theme-chalk/src/icon\";\r\n@import \"~element-ui/packages/theme-chalk/src/input\";\r\n@import \"~element-ui/packages/theme-chalk/src/loading\";\r\n@import \"~element-ui/packages/theme-chalk/src/pagination\";\r\n\r\n.content-card {\r\n height: 100%;\r\n flex-flow: column;\r\n display: flex;\r\n}\r\n\r\n.button {\r\n background-color: $app-primary-color;\r\n border: $app-primary-color;\r\n color: white;\r\n}\r\n\r\n.step-item {\r\n font-size: 14px;\r\n margin-bottom: 18px;\r\n text-align: left;\r\n}\r\n\r\n.search-input {\r\n width: 298px !important;\r\n height: 40px;\r\n padding-right: 14px;\r\n align-items: left;\r\n}\r\n\r\n.header {\r\n border: solid 1px #292b66;\r\n background-color: #292b66;\r\n text-align: left;\r\n}\r\n\r\n.pagination {\r\n padding-bottom: 16px;\r\n background-color: white;\r\n text-align: center;\r\n}\r\n\r\n.pagination ::v-deep button {\r\n background-color: white !important;\r\n}\r\n.pagination ::v-deep li {\r\n background-color: white !important;\r\n}\r\n.pagination ::v-deep li.active {\r\n color: $app-primary-color;\r\n}\r\n\r\n.error-feedback {\r\n font-family: Asap;\r\n font-size: 14px;\r\n font-style: italic;\r\n padding-top: 15px;\r\n}\r\n\r\n.content-card ::v-deep .el-card__header {\r\n background-color: #292b66;\r\n border: solid 1px #292b66;\r\n}\r\n\r\n.content-card ::v-deep .el-card__body {\r\n background-color: #f7faff;\r\n overflow-y: hidden;\r\n}\r\n\r\n.content {\r\n width: 518px;\r\n flex: 1 1 auto;\r\n box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.06);\r\n border: solid 1px #e4e7ed;\r\n background-color: #ffffff;\r\n overflow-y: scroll;\r\n scrollbar-width: thin;\r\n}\r\n\r\n.content ::v-deep .el-loading-spinner .path {\r\n stroke: $app-primary-color;\r\n}\r\n\r\n.content ::v-deep .step-item:first-child .seperator-path {\r\n display: none;\r\n}\r\n\r\n.content ::v-deep .step-item:not(:first-child) .seperator-path {\r\n width: 486px;\r\n height: 0px;\r\n border: solid 1px #e4e7ed;\r\n background-color: #e4e7ed;\r\n}\r\n\r\n.scrollbar::-webkit-scrollbar-track {\r\n border-radius: 10px;\r\n background-color: #f5f5f5;\r\n}\r\n\r\n.scrollbar::-webkit-scrollbar {\r\n width: 12px;\r\n right: -12px;\r\n background-color: #f5f5f5;\r\n}\r\n\r\n.scrollbar::-webkit-scrollbar-thumb {\r\n border-radius: 4px;\r\n box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.06);\r\n background-color: #979797;\r\n}\r\n\r\n::v-deep .el-input__suffix {\r\n padding-right: 10px;\r\n}\r\n\r\n::v-deep .my-drawer {\r\n background: rgba(0, 0, 0, 0);\r\n box-shadow: none;\r\n}\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SidebarContent.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SidebarContent.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SidebarContent.vue?vue&type=template&id=33c92dc7&scoped=true&\"\nimport script from \"./SidebarContent.vue?vue&type=script&lang=js&\"\nexport * from \"./SidebarContent.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SidebarContent.vue?vue&type=style&index=0&id=33c92dc7&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"33c92dc7\",\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"tab-container\"},_vm._l((_vm.tabTitles),function(title){return _c('div',{key:title.id,staticClass:\"title\"},[_c('div',{staticClass:\"title-text-table\",class:{ highlightText : (title.id==_vm.activeId) },on:{\"click\":function($event){return _vm.titleClicked(title.id)}}},[_c('div',{staticClass:\"title-text\"},[_vm._v(\" \"+_vm._s(title.title)+\" \")])])])}),0)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\r\n <div class=\"tab-container\">\r\n <div class=\"title\" v-for=\"title in tabTitles\" :key=\"title.id\">\r\n <div class=\"title-text-table\" v-bind:class=\"{ highlightText : (title.id==activeId) }\" v-on:click=\"titleClicked(title.id)\">\r\n <div class=\"title-text\">\r\n {{title.title}}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\n\r\nexport default {\r\n name: \"Tabs\",\r\n props: {\r\n tabTitles: {\r\n type: Array,\r\n default: () => []\r\n },\r\n activeId: {\r\n type: Number,\r\n default: 1\r\n }\r\n },\r\n methods: {\r\n titleClicked: function(id) {\r\n this.$emit(\"titleClicked\", id);\r\n },\r\n }\r\n\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n\r\n.tab-container{\r\n height: 28px;\r\n}\r\n\r\n.title {\r\n width: 101px;\r\n height: 28px;\r\n border: solid 1px $lineColor1;\r\n border-bottom: none;\r\n background-color: white;\r\n display:inline-block;\r\n}\r\n\r\n.title:hover {\r\n cursor: pointer;\r\n}\r\n\r\n.title-text {\r\n text-align:center;\r\n display: table-cell;\r\n vertical-align: middle;\r\n font-size: 14px;\r\n}\r\n\r\n.title-text-table {\r\n display:table;\r\n height: 100%;\r\n width: 100%;\r\n}\r\n\r\n.parent-dialog:hover .title-text {\r\n color:$app-primary-color;\r\n}\r\n\r\n.highlightText {\r\n color:$app-primary-color;\r\n}\r\n\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Tabs.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Tabs.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./Tabs.vue?vue&type=template&id=6bfde6c2&scoped=true&\"\nimport script from \"./Tabs.vue?vue&type=script&lang=js&\"\nexport * from \"./Tabs.vue?vue&type=script&lang=js&\"\nimport style0 from \"./Tabs.vue?vue&type=style&index=0&id=6bfde6c2&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"6bfde6c2\",\n null\n \n)\n\nexport default component.exports","<template>\r\n <div ref=\"container\">\r\n <div v-if=\"!drawerOpen\" @click=\"toggleDrawer\" class=\"open-tab\">\r\n <i class=\"el-icon-arrow-left\"></i>\r\n </div>\r\n <el-drawer\r\n custom-class=\"my-drawer\"\r\n class=\"side-bar\"\r\n :visible.sync=\"drawerOpen\"\r\n :appendToBody=\"false\"\r\n :modal-append-to-body=\"false\"\r\n size=550\r\n :with-header=\"false\"\r\n :wrapperClosable=\"false\"\r\n :modal=\"false\"\r\n >\r\n <div class=\"box-card\">\r\n <div v-if=\"drawerOpen\" @click=\"close\" class=\"close-tab\">\r\n <i class=\"el-icon-arrow-right\"></i>\r\n </div>\r\n <div class=\"sidebar-container\">\r\n <tabs v-if=\"tabs.length > 1\" :tabTitles=\"tabs\" :activeId=\"activeId\"\r\n @titleClicked=\"tabClicked\"/>\r\n <template v-for=\"tab in tabs\">\r\n <sidebar-content class=\"sidebar-content-container\"\r\n v-show=\"tab.id===activeId\" :contextCardEntry=\"tab.contextCard\"\r\n :envVars=\"envVars\"\r\n v-bind:key=\"tab.id\" :ref=\"tab.id\"\r\n @search-changed=\"searchChanged(tab.id, $event)\"/>\r\n </template>\r\n </div>\r\n </div>\r\n </el-drawer>\r\n </div>\r\n</template>\r\n\r\n\r\n<script>\r\n/* eslint-disable no-alert, no-console */\r\nimport Vue from \"vue\";\r\nimport {\r\n Drawer,\r\n Icon,\r\n} from \"element-ui\";\r\nimport lang from \"element-ui/lib/locale/lang/en\";\r\nimport locale from \"element-ui/lib/locale\";\r\nimport SidebarContent from './SidebarContent.vue';\r\nimport EventBus from './EventBus';\r\nimport Tabs from './Tabs'\r\n\r\nlocale.use(lang);\r\nVue.use(Drawer);\r\nVue.use(Icon);\r\n\r\nexport default {\r\n components: {SidebarContent, Tabs },\r\n name: \"SideBar\",\r\n props: {\r\n visible: {\r\n type: Boolean,\r\n default: false\r\n },\r\n envVars: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n tabs: {\r\n type: Array,\r\n default: () => [{title:'flatmap', id:1}]\r\n },\r\n activeId: {\r\n type: Number,\r\n default: 1\r\n },\r\n openAtStart: {\r\n type: Boolean,\r\n default: false\r\n }\r\n },\r\n data: function () {\r\n return {\r\n drawerOpen: false,\r\n }\r\n },\r\n methods: {\r\n searchChanged: function (id, data) {\r\n this.$emit(\"search-changed\", {...data, id: id});\r\n },\r\n close: function () {\r\n this.drawerOpen = false;\r\n },\r\n toggleDrawer: function () {\r\n this.drawerOpen = !this.drawerOpen;\r\n },\r\n openSearch: function(facets, query){\r\n this.drawerOpen = true;\r\n // Because refs are in v-for, nextTick is needed here\r\n Vue.nextTick(()=>{this.$refs[this.activeId][0].openSearch(facets, query)})\r\n },\r\n addFilter: function(filter){\r\n this.drawerOpen = true;\r\n filter.AND = true // When we add a filter external, it is currently only with an AND boolean\r\n\r\n // Because refs are in v-for, nextTick is needed here\r\n Vue.nextTick(()=>{this.$refs[this.activeId][0].addFilter(filter)})\r\n },\r\n openNeuronSearch: function(neuron){\r\n this.drawerOpen = true;\r\n // Because refs are in v-for, nextTick is needed here\r\n Vue.nextTick(()=>{this.$refs[this.activeId][0].openSearch('', undefined, 'scicrunch-query-string/', {'field': '*organ.curie', 'curie':neuron})})\r\n },\r\n getAlgoliaFacets: async function(){\r\n return await this.$refs[this.activeId][0].getAlgoliaFacets()\r\n },\r\n setDrawerOpen: function(value=true){\r\n this.drawerOpen = value;\r\n },\r\n tabClicked: function(id) {\r\n this.$emit(\"tabClicked\", id);\r\n },\r\n },\r\n created:function() {\r\n this.drawerOpen = this.openAtStart;\r\n },\r\n mounted: function(){\r\n EventBus.$on(\"PopoverActionClick\", (payLoad) => {\r\n this.$emit(\"actionClick\", payLoad);\r\n })\r\n EventBus.$on('available-facets', (payLoad)=> {\r\n this.$emit('search-changed', {\r\n type: 'available-facets',\r\n value: payLoad\r\n })\r\n })\r\n EventBus.$on('contextUpdate', (payLoad)=> {\r\n this.$emit('contextUpdate', payLoad)\r\n })\r\n }\r\n};\r\n</script>\r\n\r\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\r\n<style scoped lang=\"scss\">\r\n@import \"~element-ui/packages/theme-chalk/src/drawer\";\r\n@import \"~element-ui/packages/theme-chalk/src/icon\";\r\n\r\n.box-card {\r\n flex: 3;\r\n height: 100%;\r\n overflow: hidden;\r\n pointer-events: auto;\r\n}\r\n\r\n.side-bar{\r\n position: relative;\r\n height: 100%;\r\n pointer-events: none;\r\n}\r\n\r\n.side-bar ::v-deep .el-drawer:focus{\r\n outline:none;\r\n}\r\n\r\n.sidebar-container {\r\n height: 100%;\r\n flex-flow: column;\r\n display: flex;\r\n}\r\n\r\n.open-tab{\r\n width: 20px;\r\n height: 40px;\r\n z-index: 8;\r\n position: absolute;\r\n top: calc(50vh - 80px);\r\n right: 0px;\r\n box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.06);\r\n border: solid 1px $app-primary-color;\r\n background-color: #f9f2fc;\r\n text-align: center;\r\n vertical-align: middle;\r\n cursor: pointer;\r\n pointer-events: auto;\r\n}\r\n\r\n.el-icon-arrow-left,\r\n.el-icon-arrow-right\r\n{\r\n font-weight: 600;\r\n margin-top: 12px;\r\n color: $app-primary-color;\r\n cursor: pointer;\r\n pointer-events: auto;\r\n transform: scaleY(2.0);\r\n text-align: center;\r\n vertical-align: middle;\r\n}\r\n\r\n.close-tab{\r\n float: left;\r\n flex: 1;\r\n width: 20px;\r\n height: 40px;\r\n z-index: 8;\r\n margin-top: calc(50vh - 80px);\r\n box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.06);\r\n border: solid 1px $app-primary-color; \r\n background-color: #f9f2fc;\r\n text-align: center;\r\n vertical-align: middle;\r\n cursor: pointer;\r\n pointer-events: auto;\r\n}\r\n\r\n.box-card {\r\n flex: 3;\r\n height: 100%;\r\n overflow: hidden;\r\n pointer-events: auto;\r\n}\r\n\r\n::v-deep .my-drawer {\r\n background: rgba(0,0,0,0);\r\n box-shadow: none;\r\n}\r\n\r\n::v-deep .my-drawer .el-drawer__body {\r\n height: 100%;\r\n}\r\n\r\n.sidebar-content-container {\r\n flex: 1 1 auto;\r\n}\r\n\r\n</style>\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SideBar.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./SideBar.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SideBar.vue?vue&type=template&id=11bc3f45&scoped=true&\"\nimport script from \"./SideBar.vue?vue&type=script&lang=js&\"\nexport * from \"./SideBar.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SideBar.vue?vue&type=style&index=0&id=11bc3f45&scoped=true&lang=scss&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"11bc3f45\",\n null\n \n)\n\nexport default component.exports","import SideBar from \"./SideBar.vue\"\r\n\r\nexport {\r\n SideBar\r\n};\r\n\r\n\r\n\r\n","import './setPublicPath'\nexport * from '~entry'\n","module.exports = require(\"core-js/modules/es.string.includes\");","module.exports = require(\"core-js/modules/es.array.find\");"],"sourceRoot":""}
|