-
Notifications
You must be signed in to change notification settings - Fork 104
/
Copy pathmarker.vue
128 lines (119 loc) · 1.92 KB
/
marker.vue
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<template>
<div>
<slot></slot>
</div>
</template>
<script>
import buildComponent from './build-component.js'
const props = {
animation: {
twoWay: true,
type: Number,
},
attribution: {
type: Object,
},
clickable: {
type: Boolean,
twoWay: true,
default: true,
},
cursor: {
type: String,
twoWay: true,
},
draggable: {
type: Boolean,
twoWay: true,
default: false,
},
icon: {
twoWay: true,
},
label: {},
opacity: {
type: Number,
default: 1,
},
options: {
type: Object,
},
place: {
type: Object,
},
position: {
type: Object,
twoWay: true,
},
shape: {
type: Object,
twoWay: true,
},
title: {
type: String,
twoWay: true,
},
zIndex: {
type: Number,
twoWay: true,
},
visible: {
twoWay: true,
default: true,
},
}
const events = [
'click',
'rightclick',
'dblclick',
'drag',
'dragstart',
'dragend',
'mouseup',
'mousedown',
'mouseover',
'mouseout',
]
export default buildComponent({
mappedProps: props,
events,
name: 'marker',
ctr: () => google.maps.Marker,
inject: {
$clusterPromise: {
default: null,
},
},
emits: events,
unmounted() {
if (!this.$markerObject) {
return
}
if (this.$clusterObject) {
// Repaint will be performed in `updated()` of cluster
this.$clusterObject.removeMarker(this.$markerObject, true)
} else {
this.$markerObject.setMap(null)
}
},
beforeCreate(options) {
if (this.$clusterPromise) {
options.map = null
}
return this.$clusterPromise
},
afterCreate(inst) {
events.forEach((event)=> {
inst.addListener(event, (payload)=> {
this.$emit(event, payload)
});
})
if (this.$clusterPromise) {
this.$clusterPromise.then((co) => {
this.$clusterObject = co
co.addMarker(inst)
})
}
},
})
</script>