mirror of
https://github.com/simon987/music-graph-ui.git
synced 2025-04-18 01:26:43 +00:00
158 lines
2.7 KiB
Vue
158 lines
2.7 KiB
Vue
<template>
|
|
<div>
|
|
<div id="mm"></div>
|
|
<InputBar v-on:query="onQuery($event)"></InputBar>
|
|
<ArtistInfo
|
|
v-bind:artist="hoverArtist"
|
|
v-on:addTag="onAddTag($event)"
|
|
/>
|
|
<canvas id="textMeasurementCanvas"></canvas>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import ArtistInfo from './ArtistInfo'
|
|
import {MusicGraph} from '../MusicGraph'
|
|
import InputBar from './InputBar'
|
|
|
|
let data = {
|
|
hoverArtist: undefined,
|
|
mm: undefined
|
|
}
|
|
|
|
export default {
|
|
components: {InputBar, ArtistInfo},
|
|
data() {
|
|
return data
|
|
},
|
|
methods: {
|
|
onQuery: function (e) {
|
|
this.mm.addArtistByMbid(e)
|
|
},
|
|
onAddTag: function(e) {
|
|
this.mm.addTagById(e)
|
|
}
|
|
},
|
|
mounted() {
|
|
this.mm = new MusicGraph(data)
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style>
|
|
svg {
|
|
margin-top: 3px;
|
|
margin-left: 3px;
|
|
|
|
-webkit-touch-callout: none;
|
|
-webkit-user-select: none;
|
|
-khtml-user-select: none;
|
|
-moz-user-select: none;
|
|
-ms-user-select: none;
|
|
user-select: none;
|
|
position: fixed;
|
|
top: 0;
|
|
}
|
|
|
|
/* Pan mode */
|
|
svg.pan-mode .node {
|
|
pointer-events: none;
|
|
}
|
|
|
|
svg.pan-mode {
|
|
cursor: move;
|
|
}
|
|
|
|
svg.pan-mode .pan-rect {
|
|
pointer-events: all;
|
|
}
|
|
|
|
svg.menu-mode .dismiss-rect {
|
|
pointer-events: all;
|
|
}
|
|
|
|
svg.pan-mode {
|
|
box-sizing: border-box;
|
|
border: 5px red solid;
|
|
}
|
|
|
|
/* Link */
|
|
svg .link.selected {
|
|
stroke-width: 2;
|
|
}
|
|
|
|
svg .link {
|
|
stroke: #FFE082;
|
|
pointer-events: none;
|
|
stroke-opacity: 0.3;
|
|
stroke-width: 1;
|
|
}
|
|
|
|
svg.hover .link:not(.selected) {
|
|
stroke-opacity: 0.5;
|
|
stroke-width: 0.2;
|
|
}
|
|
|
|
/* Node */
|
|
svg .node.selected {
|
|
stroke: #7C4DFF;
|
|
}
|
|
|
|
svg .node.hover {
|
|
stroke: #7C4DFF;
|
|
}
|
|
|
|
svg.hover .node:not(.selected):not(.hover) {
|
|
display: none;
|
|
}
|
|
|
|
svg .node {
|
|
fill: transparent;
|
|
stroke-width: 2;
|
|
}
|
|
|
|
/* Label */
|
|
svg .label {
|
|
text-anchor: middle;
|
|
font-family: Tahoma, sans-serif;
|
|
font-size: 11px;
|
|
}
|
|
|
|
svg .label.release {
|
|
fill: darkgrey;
|
|
}
|
|
|
|
svg .label.tag {
|
|
fill: darkgrey;
|
|
}
|
|
|
|
svg.hover .label:not(.selected) {
|
|
fill-opacity: 0.2;
|
|
}
|
|
|
|
body {
|
|
background: #ffffff;
|
|
}
|
|
|
|
/* test */
|
|
|
|
#menu .menu-item {
|
|
cursor: pointer;
|
|
fill: #FFB300;
|
|
}
|
|
|
|
#menu .menu-item.hover {
|
|
fill: #FF8F00;
|
|
}
|
|
|
|
#menu .menu-icon {
|
|
fill: black;
|
|
stroke: black;
|
|
pointer-events: none;
|
|
}
|
|
|
|
text {
|
|
pointer-events: none;
|
|
}
|
|
</style>
|