26
26
avatar: false
27
27
},
28
28
actions: [
29
+ {
30
+ id: 'apply-to-layer',
31
+ component: 'menu/KMenu',
32
+ icon: 'las la-layer-group',
33
+ tooltip: 'KStyleManager.APPLY_TO_LAYER',
34
+ actionRenderer: 'item',
35
+ content: layerMenuContent
36
+ },
29
37
{
30
38
id: 'apply-to-selection',
31
- icon: 'las la-object-ungroup ',
39
+ icon: 'las la-object-group ',
32
40
tooltip: 'KStyleManager.APPLY_TO_SELECTION',
33
- scope: 'header',
34
41
handler: applyToSelection
35
42
},
36
43
{
37
44
id: 'edit-style',
38
45
icon: 'las la-edit',
39
46
tooltip: 'KStyleManager.EDIT',
40
- scope: 'header',
41
47
handler: editStyle
42
48
},
43
49
{
44
50
id: 'delete-style',
45
51
icon: 'las la-trash',
46
52
tooltip: 'KStyleManager.DELETE',
47
- scope: 'footer',
48
53
handler: { name: 'removeItem', params: ['confirm'] }
49
54
},
50
55
],
63
68
<script setup>
64
69
import { computed , ref } from ' vue'
65
70
import _ from ' lodash'
71
+ import sift from ' sift'
66
72
import { KGrid } from ' ../../../../core/client/components'
67
73
import { Store , api } from ' @kalisio/kdk/core.client'
68
74
import KStyleEditor from ' ./KStyleEditor.vue'
69
75
import { useCurrentActivity } from ' ../../composables/activity.js'
70
- import { isLayerStyleEditable } from ' ../../utils/utils.layers.js'
76
+ import { isLayerStyleEditable , editLayerStyle } from ' ../../utils/utils.layers.js'
71
77
import { editFeaturesStyle } from ' ../../utils/utils.features.js'
72
78
73
79
// Props
@@ -79,11 +85,11 @@ defineProps({
79
85
})
80
86
81
87
// Data
88
+ const { getSelectedFeaturesByLayer , CurrentActivity } = useCurrentActivity ()
82
89
const filter = Store .get (' filter' )
83
90
const styleEditor = ref (null )
84
91
const style = ref (null )
85
92
const viewMode = ref (' list' )
86
- const { getSelectedFeaturesByLayer } = useCurrentActivity ()
87
93
88
94
// Computed
89
95
const baseQuery = computed (() => {
@@ -121,8 +127,21 @@ const toolbar = computed(() => {
121
127
}
122
128
]
123
129
})
130
+ const layerMenuContent = computed (() => {
131
+ const visibleLayers = CurrentActivity .value .getLayers ().filter (sift ({ isVisible: true , scope: ' user' , _id: { $exists: true } }))
132
+ return _ .map (visibleLayers, layer => {
133
+ return {
134
+ id: layer ._id ,
135
+ label: layer .name ,
136
+ handler : (styleToApply ) => applyToLayer (layer, styleToApply .item )
137
+ }
138
+ })
139
+ })
124
140
125
141
// Functions
142
+ function applyToLayer (layer , styleToApply ) {
143
+ editLayerStyle (layer, styleToApply)
144
+ }
126
145
function applyToSelection (styleToApply ) {
127
146
const type = { Point : ' point' , LineString: ' line' , Polygon: ' polygon' }
128
147
_ .forEach (getSelectedFeaturesByLayer (), layer => {
@@ -134,7 +153,7 @@ function applyToSelection (styleToApply) {
134
153
}
135
154
function editStyle (styleToEdit ) {
136
155
viewMode .value = ' edit'
137
- style .value = _ .get (styleToEdit, ' item' , null )
156
+ style .value = _ .get (styleToEdit, ' item' , {} )
138
157
}
139
158
function onApply (style ) {
140
159
const service = api .getService (' styles' )
0 commit comments