Skip to content

Commit a3cad40

Browse files
committed
fix: allow to refresh all contexts (redhat-developer#809)
Signed-off-by: Andre Dietisheim <[email protected]>
1 parent 719d72c commit a3cad40

File tree

2 files changed

+29
-7
lines changed

2 files changed

+29
-7
lines changed

src/main/kotlin/com/redhat/devtools/intellij/kubernetes/actions/RefreshAction.kt

+27-6
Original file line numberDiff line numberDiff line change
@@ -23,15 +23,36 @@ import javax.swing.tree.TreePath
2323
class RefreshAction : StructureTreeAction(IActiveContext::class.java) {
2424

2525
override fun actionPerformed(event: AnActionEvent?, path: TreePath?, selectedNode: Any?) {
26-
val descriptor = selectedNode?.getDescriptor() ?: return
27-
run("Refreshing $selectedNode...", true,
26+
val descriptor = selectedNode?.getDescriptor()
27+
run("Refreshing ${ selectedNode ?: "all contexts" }...", true,
2828
Progressive {
29-
val telemetry = TelemetryService.instance.action("refresh resource")
29+
val telemetry = TelemetryService.instance.action(
30+
"refresh ${
31+
if (descriptor != null) {
32+
"resource"
33+
} else {
34+
"all contexts"
35+
}
36+
} "
37+
)
3038
try {
31-
descriptor.invalidate()
32-
sendTelemetry(getResourceKind(descriptor.element), telemetry)
39+
if (descriptor != null) {
40+
descriptor.invalidate()
41+
sendTelemetry(getResourceKind(descriptor.element), telemetry)
42+
} else {
43+
getResourceModel()?.invalidate();
44+
telemetry.send()
45+
}
3346
} catch (e: Exception) {
34-
logger<RefreshAction>().warn("Could not refresh $descriptor resources.", e)
47+
logger<RefreshAction>().warn(
48+
"Could not refresh ${
49+
if (descriptor != null) {
50+
"$descriptor resources"
51+
} else {
52+
"all contexts."
53+
}
54+
}", e
55+
)
3556
telemetry.error(e).send()
3657
}
3758
})

src/main/kotlin/com/redhat/devtools/intellij/kubernetes/model/ResourceModel.kt

+2-1
Original file line numberDiff line numberDiff line change
@@ -50,6 +50,7 @@ interface IResourceModel {
5050
fun watch(definition: CustomResourceDefinition)
5151
fun stopWatch(kind: ResourceKind<out HasMetadata>)
5252
fun stopWatch(definition: CustomResourceDefinition)
53+
fun invalidate()
5354
fun invalidate(element: Any?)
5455
fun delete(resources: List<HasMetadata>, force: Boolean)
5556
fun canWatchLog(resource: HasMetadata): Boolean
@@ -171,7 +172,7 @@ open class ResourceModel : IResourceModel {
171172
modelChange.removeListener(listener)
172173
}
173174

174-
private fun invalidate() {
175+
override fun invalidate() {
175176
logger<ResourceModel>().debug("Invalidating all contexts.")
176177
allContexts.refresh()
177178
}

0 commit comments

Comments
 (0)