summaryrefslogtreecommitdiffstats
path: root/src/org.gluster.storage.management.console/src/org/gluster/storage/management/console/views/VolumeLogsView.java
blob: 1622dbfb9cc6b0a8557d9ee7a28c77fede28c5d6 (plain)
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
package org.gluster.storage.management.console.views;

import org.eclipse.jface.dialogs.MessageDialog;
import org.eclipse.jface.viewers.DoubleClickEvent;
import org.eclipse.jface.viewers.IDoubleClickListener;
import org.eclipse.jface.viewers.StructuredSelection;
import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.ui.part.ViewPart;
import org.gluster.storage.management.console.utils.GUIHelper;
import org.gluster.storage.management.console.views.pages.VolumeLogsPage;
import org.gluster.storage.management.core.constants.CoreConstants;
import org.gluster.storage.management.core.model.Volume;
import org.gluster.storage.management.core.model.VolumeLogMessage;
import org.gluster.storage.management.core.utils.DateUtil;


public class VolumeLogsView extends ViewPart implements IDoubleClickListener {
	VolumeLogsPage logsPage;
	public static final String ID = VolumeLogsView.class.getName();
	private static final GUIHelper guiHelper = GUIHelper.getInstance();
	private Volume volume;

	@Override
	public void createPartControl(Composite parent) {
		if (volume == null) {
			volume = guiHelper.getSelectedEntity(getSite(), Volume.class);
		}

		createPage(parent);
	}

	private void createPage(Composite parent) {
		logsPage = new VolumeLogsPage(parent, SWT.NONE, volume);
		logsPage.addDoubleClickListener(this);
		
		parent.layout(); // IMP: lays out the form properly
	}

	@Override
	public void setFocus() {
		logsPage.setFocus();
	}
	
	@Override
	public void doubleClick(DoubleClickEvent event) {
		VolumeLogMessage volumeLogMessage = (VolumeLogMessage) ((StructuredSelection) event.getSelection())
				.getFirstElement();
		String message = DateUtil.formatDate(volumeLogMessage.getTimestamp()) + " "
				+ DateUtil.formatTime(volumeLogMessage.getTimestamp()) + " [" + volumeLogMessage.getSeverity() + "]"
				+ CoreConstants.NEWLINE + CoreConstants.NEWLINE + volumeLogMessage.getMessage();

		new MessageDialog(getSite().getShell(), "Log message from " + volumeLogMessage.getBrick(), null, message,
				MessageDialog.NONE, new String[] { "Close" }, 0).open();

	}
}