-
Notifications
You must be signed in to change notification settings - Fork 4
/
WaypointMapItemExtensionModule.vb
54 lines (51 loc) · 2.42 KB
/
WaypointMapItemExtensionModule.vb
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
Imports DevExpress.DashboardCommon
Imports DevExpress.DashboardWin
Imports DevExpress.XtraBars
Imports DevExpress.XtraBars.Ribbon
Namespace DevExpress.DashboardWin.CustomItemExtension
Public Class WaypointMapItemExtensionModule
Implements IExtensionModule
Private dashboardControl As IDashboardControl
Private bingKey As String
Public Sub New(ByVal bingKey As String)
Me.bingKey = bingKey
End Sub
Public Sub AttachViewer(ByVal viewer As DashboardViewer) Implements IExtensionModule.AttachViewer
AttachDashboardControl(viewer)
End Sub
Public Sub DetachViewer() Implements IExtensionModule.DetachViewer
Detach()
End Sub
Public Sub AttachDesigner(ByVal designer As DashboardDesigner) Implements IExtensionModule.AttachDesigner
AttachDashboardControl(designer)
designer.CreateCustomItemBars(GetType(WaypointMapItemMetadata))
RemoveDrillDownBarItem(designer)
End Sub
Public Sub DetachDesigner() Implements IExtensionModule.DetachDesigner
Detach()
End Sub
Private Sub Detach()
If dashboardControl IsNot Nothing Then
RemoveHandler dashboardControl.CustomDashboardItemControlCreating, AddressOf OnCustomDashboardItemControlCreating
End If
End Sub
Private Sub AttachDashboardControl(ByVal dashboardControl As IDashboardControl)
If dashboardControl IsNot Nothing Then
Me.dashboardControl = dashboardControl
AddHandler dashboardControl.CustomDashboardItemControlCreating, AddressOf OnCustomDashboardItemControlCreating
End If
End Sub
Private Sub OnCustomDashboardItemControlCreating(ByVal sender As Object, ByVal e As CustomDashboardItemControlCreatingEventArgs)
Dim dashboardControl As IDashboardControl = DirectCast(sender, IDashboardControl)
If e.MetadataType Is GetType(WaypointMapItemMetadata) Then
e.CustomControlProvider = New WaypointMapItemControlProvider(TryCast(dashboardControl.Dashboard.Items(e.DashboardItemName), CustomDashboardItem(Of WaypointMapItemMetadata)), bingKey)
End If
End Sub
Private Sub RemoveDrillDownBarItem(ByVal designer As DashboardDesigner)
Dim page As RibbonPage = designer.Ribbon.GetDashboardRibbonPage(GetType(WaypointMapItemMetadata), DashboardRibbonPage.Data)
Dim interactivityGroup As RibbonPageGroup = page.Groups(1)
Dim drillDownBarItem As BarItem = interactivityGroup.ItemLinks(2).Item
interactivityGroup.ItemLinks.Remove(drillDownBarItem)
End Sub
End Class
End Namespace