import "vue"; import { u as d, e as u, E as r, T as p, f as h, i as m } from "./index-Dm_oomn1.js"; import { mapStores as g } from "pinia"; function y(e) { return e[0].toUpperCase() + e.substring(1); } const w = { emits: ["flatmap-provenance-ready", "resource-selected", "species-changed"], props: { /** * Object containing information for * the required viewing. */ entry: Object, visible: { type: Boolean, default: !0 }, mouseHovered: { type: Boolean, default: !1 } }, computed: { ...g(d, u), idNamePair() { return this.splitFlowStore.idNamePair; }, syncMode() { return this.splitFlowStore.syncMode; }, useHelpModeDialog() { return this.settingsStore.useHelpModeDialog; }, connectivityInfoSidebar() { return this.settingsStore.connectivityInfoSidebar; }, annotationSidebar() { return this.settingsStore.annotationSidebar; } }, mounted: function() { r.on("startHelp", () => { this.startHelp(); }), this.multiflatmapRef = this.$refs.multiflatmap, this.flatmapRef = this.$refs.flatmap, this.scaffoldRef = this.$refs.scaffold; }, methods: { toggleSyncMode: function() { }, getState: function() { }, openMap: function(e) { e === "SYNC" ? (this.toggleSyncMode(), this.trackOpenMap("toggle_map_sync_mode")) : (r.emit("OpenNewMap", e), this.trackOpenMap(`open_new_${e}_map`)), this.onConnectivityInfoClose(); }, onMapmanagerLoaded: function(e) { this.settingsStore.updateMapManager(e); }, trackOpenMap: function(e) { p.sendEvent({ event: "interaction_event", event_name: "portal_maps_open_map", category: e, location: "open_new_map" }); }, updateWithViewUrl: function() { }, /** * Perform a local search on this contentvuer */ search: function() { return !1; }, /** * Get a list of search suggestions on this contentvuer */ searchSuggestions: function() { }, /** * Callback when the vuers emit a selected event. */ resourceSelected: function(e, t) { var n, o, l, f; if (this.resourceHasAction(t)) { r.emit("PopoverActionClick", t); return; } let i, s = !1; const a = { paneIndex: this.entry.id, type: e, resource: t, internalName: void 0, eventType: void 0 }; if (e == "MultiFlatmap" || e == "Flatmap") if (a.internalName = (n = t == null ? void 0 : t.feature) != null && n.label ? t.feature.label : this.idNamePair[t.feature.models], t.eventType == "click") if (a.eventType = "selected", t.feature.type == "marker") { let c = a.internalName; this.settingsStore.isFeaturedMarkerIdentifier( t.feature.id ) ? i = { type: "Search", term: this.settingsStore.featuredMarkerDoi( t.feature.id ), featuredDataset: !0 } : i = { type: "Facet", facet: c, facetPropPath: "anatomy.organ.category.name", term: "Anatomical structure" }, s = !0, e == "MultiFlatmap" && this.$refs.multiflatmap.getCurrentFlatmap().mapImp.clearSearchResults(); } else t.feature.type == "feature" && this.syncMode && (s = !0); else t.eventType == "mouseenter" && (a.eventType = "highlighted", s = !0); else e == "Scaffold" && (t && t[0] && ((((o = t[0].data) == null ? void 0 : o.id) === void 0 || ((l = t[0].data) == null ? void 0 : l.id) === "") && (t[0].data.id = (f = t[0].data) == null ? void 0 : f.group), a.internalName = t[0].data.id, t[0].data.lastActionOnMarker === !0 && (i = { type: "Facet", facet: y(t[0].data.id), facetPropPath: "anatomy.organ.category.name", term: "Anatomical structure" })), a.eventType = "selected", s = !0); i && r.emit("PopoverActionClick", i), s && this.$emit("resource-selected", a); }, resourceHasAction: function(e) { return e.type === "URL" || e.type === "Search" || e.type === "Neuron Search" || e.type == "Facet" || e.type == "Facets"; }, /** * Check if this viewer is currently visible */ isVisible: function() { return this.splitFlowStore.getPaneNameById(this.entry.id) !== void 0; }, displayTooltip: function() { }, /** * Get the term to zoom/highlight in a synchronisation event, * if it cannot be found in the map, it will perform several * calls to try to ge a valid name/id. */ getNameAndIdFromSyncData: async function(e) { let t = e.internalName; t === void 0 && e.resource && (t = e.resource.label); let i; if (e.resource && e.resource.resource && (i = e.resource.resource[0]), this.entry.type === "Scaffold") { if (this.$refs.scaffold.findObjectsWithGroupName(t).length === 0) { if (e.resource && e.resource.feature) { const n = h(e.resource.feature.models); if (n.length > 0) return n; } let a = m(t); if (a) return a; if (i && e.eventType === "selected") return fetch(`${this.apiLocation}get-related-terms/${i}`).then((n) => n.json()).then((n) => { if (n.uberon.array.length > 0) return t = n.uberon.array[0].name.charAt(0).toUpperCase() + n.uberon.array[0].name.slice(1), i = n.uberon.array[0].id.toUpperCase(), { id: i, name: t }; }); } } else if (this.entry.type === "MultiFlatmap") if (t === "Bladder") t = "Urinary Bladder"; else { const s = h(t); s.length > 0 && (t = s[0]); } return { id: i, name: t }; }, // Get the species and andaotmy info for the featured datasets getDatasetAnatomyInfo: function(e) { fetch(`${this.apiLocation}dataset_info/anatomy?identifier=${e}`).then((t) => t.json()).then((t) => { const i = t.result[0]; let s; try { s = i.anatomy.organ[0].curie; } catch { s = void 0; } let a; try { a = i.item.curie; } catch { a = void 0; } let n; try { let o = 0, l = !1; for (; !l && o < i.organisms.subject.length; ) { const f = i.organisms.subject[o]; f.species && (n = f.species.name, l = !0), o += 1; } } catch { n = void 0; } this.settingsStore.updateFeaturedMarker({ identifier: e, marker: s, doi: a, species: n }); }); }, // Check if the old featured dataset api has any info oldFeaturedDatasetApiHasInfo: async function() { let t = await (await fetch(`${this.apiLocation}get_featured_datasets_identifiers`)).json(); return !t.identifiers || t.identifiers.length == 0 ? !1 : t.identifiers; }, // Check if the new featured dataset api has any info newFeaturedDatasetApiHasInfo: async function() { let t = await (await fetch(`${this.apiLocation}get_featured_dataset`)).json(); return !t.datasets || t.datasets.length == 0 ? !1 : t.datasets.map((i) => i.id); }, /** * Get a list of featured datasets to display. */ getFeaturedDatasets: async function() { let e = [], t = await this.oldFeaturedDatasetApiHasInfo(); if (t) e = t; else { let i = await this.newFeaturedDatasetApiHasInfo(); i && (e = i); } this.settingsStore.updateFeatured(e), e.forEach((i) => { this.getDatasetAnatomyInfo(i); }); }, zoomToFeatures: function() { }, handleSyncMouseEvent: async function(e) { let t = await this.getNameAndIdFromSyncData(e); e.eventType === "highlighted" ? this.highlightFeatures(t) : e.eventType === "selected" && this.displayTooltip(t); }, /** * Handle sync pan zoom event */ handleSyncPanZoomEvent: function() { }, highlightFeatures: function() { }, receiveSynchronisedEvent: async function(e) { if (e.paneIndex !== this.entry.id) e.eventType == "panZoom" || this.handleSyncMouseEvent(e); else if (e.eventType == "selected") { let t = await this.getNameAndIdFromSyncData(e); this.zoomToFeatures(t, !1); } }, requestSynchronisedEvent: function() { }, flatmapMarkerUpdate() { }, onResize: function() { }, startHelp: function() { this.isInHelp === !1 && (this.helpMode = !0, window.addEventListener("mousedown", this.checkEndHelpMouseDown), this.isInHelp = !0); }, endHelp: function() { window.removeEventListener("mousedown", this.checkEndHelpMouseDown), this.helpMode = !1, setTimeout(() => { this.isInHelp = !1; }, 200); }, onHelpModeShowNext: function() { this.helpModeActiveItem += 1; }, onHelpModeLastItem: function(e) { e && (this.helpModeLastItem = !0); }, onFinishHelpMode: function() { this.helpMode = !1, this.helpModeActiveItem = 0, this.helpModeLastItem = !1; }, onTooltipShown: function() { this.$refs.multiflatmap && this.$refs.multiflatmapHelp && this.$refs.multiflatmapHelp.toggleTooltipHighlight(), this.$refs.flatmap && this.$refs.flatmapHelp && this.$refs.flatmapHelp.toggleTooltipHighlight(), this.$refs.scaffold && this.$refs.scaffoldHelp && this.$refs.scaffoldHelp.toggleTooltipHighlight(); }, onMapTooltipShown: function() { this.$refs.multiflatmap && this.$refs.multiflatmapHelp && this.$refs.multiflatmapHelp.toggleTooltipPinHighlight(), this.$refs.flatmap && this.$refs.flatmapHelp && this.$refs.flatmapHelp.toggleTooltipPinHighlight(), this.$refs.scaffold && this.$refs.scaffoldHelp && this.$refs.scaffoldHelp.toggleTooltipPinHighlight(); }, /** * End help-mode only if user clicks outside of help mode dialog. */ checkEndHelpMouseDown: function(e) { e.target.closest(".help-mode-dialog") || this.endHelp(); }, mapHoverHighlight: function(e) { if (this.visible) { const t = this.settingsStore.hoverAnatomies, i = this.settingsStore.hoverOrgans; t.length || i.length ? (clearTimeout(this.hoverDelay), this.multiflatmapRef || this.flatmapRef ? e == null || e.zoomToFeatures(t, { noZoomIn: !0 }) : this.scaffoldRef && (e == null || e.changeHighlightedByName(i, "", !1))) : this.hoverDelay = setTimeout(() => { this.multiflatmapRef || this.flatmapRef ? e == null || e.clearSearchResults() : this.scaffoldRef && (e == null || e.changeHighlightedByName(i, "", !1)); }, 500); } }, onAnnotationOpen: function(e) { r.emit("annotation-open", e); }, onAnnotationClose: function() { r.emit("annotation-close"); }, onConnectivityInfoOpen: function(e) { r.emit("connectivity-info-open", e); }, onConnectivityInfoClose: function() { r.emit("connectivity-info-close"); }, onConnectivityGraphError: function(e) { r.emit("connectivity-graph-error", e); } }, data: function() { return { apiLocation: void 0, activeSpecies: "Human Male", scaffoldCamera: void 0, mainStyle: { height: this.entry.datasetTitle ? "calc(100% - 30px)" : "100%", width: "100%", bottom: "0px" }, helpMode: !1, helpModeActiveItem: 0, helpModeLastItem: !1, multiflatmapRef: null, flatmapRef: null, scaffoldRef: null, scaffoldLoaded: !1, isInHelp: !1, hoverDelay: void 0, mapManager: void 0 }; }, created: function() { this.flatmapAPI = void 0, this.apiLocation = void 0, this.settingsStore.flatmapAPI && (this.flatmapAPI = this.settingsStore.flatmapAPI), this.settingsStore.sparcApi && (this.apiLocation = this.settingsStore.sparcApi), this.settingsStore.mapManager && (this.mapManager = this.settingsStore.mapManager); }, watch: { helpMode: function(e) { e || (this.helpModeActiveItem = 0); } } }; export { w as C };