aboutsummaryrefslogtreecommitdiffstats
path: root/winery/org.eclipse.winery.topologymodeler/src/main/webapp/WEB-INF/tags/common/templates/toggleButtons.tag
blob: 05ed289140e11b66c7f0408c5ef69d452ccdbdd2 (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
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
129
130
131
<%--
/*******************************************************************************
 * Copyright (c) 2013 University of Stuttgart.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * and the Apache License 2.0 which both accompany this distribution,
 * and are available at http://www.eclipse.org/legal/epl-v10.html
 * and http://www.apache.org/licenses/LICENSE-2.0
 *
 * Contributors:
 *    Oliver Kopp - initial API and implementation and/or initial documentation
 *******************************************************************************/
--%>
<%@tag description="Toggle buttons for visual appearance" pageEncoding="UTF-8"%>
<script>
var JQUERY_ANIMATION_DURATION = 400;

function doShowOrHide(elements, showThem) {
	if (elements.length == 0) {
		// e.g., no properties defined
		return;
	}
	if (showThem) {
		elements.slideDown();
	} else {
		elements.slideUp();
	}
	window.setTimeout(function() {
		jsPlumb.repaint(elements.parent());
	}, JQUERY_ANIMATION_DURATION);
}

function showIds(cb) {
	var elements;
	if ($("div.NodeTemplateShape.selected").size() > 0) {
		elements = $("div.NodeTemplateShape.selected div.id.nodetemplate");
	} else {
		elements = $("div.NodeTemplateShape:visible div.id.nodetemplate");
	}

	if ($(cb).hasClass("active")) {
		elements.fadeOut();
	} else {
		elements.fadeIn();
	}
	// no repaint required as no nodes are moved
	// window.setTimeout(jsPlumb.repaintEverything, JQUERY_ANIMATION_DURATION);
}

/**
 * Toogles visiblity of both node types and relationship types
 */
function showTypes(showThem) {
	// types at node templates
	var elements;
	var typesOfRelationshipTemplates;
	if ($("div.NodeTemplateShape.selected").size() > 0) {
		elements = $("div.NodeTemplateShape.selected div.type.nodetemplate");
		// TODO: We should put into typesOfRelationshipTemplates all type divs of relationshiptemplates connecting highlighted node templates
		//       This should be done when doing the multiselect
		//       And there should be a second if similar to the node templates for relationship templates
		typesOfRelationshipTemplates = $(".todo");
	} else {
		elements = $("div.NodeTemplateShape:visible div.type.nodetemplate");
		// TODO: we should check for a single relationship template being selected
		typesOfRelationshipTemplates = $(".relationshipTypeLabel");
	}

	if (showThem) {
		elements.fadeIn();
		typesOfRelationshipTemplates.fadeIn();
	} else {
		elements.fadeOut();
		typesOfRelationshipTemplates.fadeOut();
	}

	// no repaint required as no nodes are moved
	// window.setTimeout(jsPlumb.repaintEverything, JQUERY_ANIMATION_DURATION);
}

function showOrHideProperties(showThem) {
	var elements;
	if ($("div.NodeTemplateShape.selected").size() > 0) {
		elements = $("div.NodeTemplateShape.selected > div.propertiesContainer");
	} else {
		elements = $("div.NodeTemplateShape:visible > div.propertiesContainer");
	}
	doShowOrHide(elements, showThem);
}


function showOrHideDeploymentArtifacts(showThem) {
	var elements;
	if ($("div.NodeTemplateShape.selected").size() > 0) {
		elements = $("div.NodeTemplateShape:visible.selected > div.deploymentArtifactsContainer");
	} else {
		elements = $("div.NodeTemplateShape:visible > div.deploymentArtifactsContainer");
	}
	doShowOrHide(elements, showThem);
}

function showOrHideReqCaps(showThem) {
	var elements;
	if ($("div.NodeTemplateShape.selected").size() > 0) {
		elements = $("div.NodeTemplateShape:visible.selected > div.requirementsContainer, div.NodeTemplateShape:visible.selected > div.capabilitiesContainer");
	} else {
		elements = $("div.NodeTemplateShape:visible > div.requirementsContainer, div.NodeTemplateShape:visible > div.capabilitiesContainer");
	}
	doShowOrHide(elements, showThem);
}

function showOrHidePolicies(showThem) {
	var elements;
	if ($("div.NodeTemplateShape.selected").size() > 0) {
		elements = $("div.NodeTemplateShape:visible.selected > div.policiesContainer");
	} else {
		elements = $("div.NodeTemplateShape:visible > div.policiesContainer");
	}
	doShowOrHide(elements, showThem);
}
</script>

<div class="btn-group" data-toggle="buttons-checkbox" id="toggleButtons">
	<button class="btn btn-default" id="toggleIdVisibility" onclick="showIds(this);">Ids</button>
	<button class="btn active" id="toggleTypeVisibility" onclick="showTypes(!$(this).hasClass('active'));">Types</button>
	<button class="btn btn-default" id="togglePropertiesVisibility" onclick="showOrHideProperties(!$(this).hasClass('active'));">Properties</button>
	<button class="btn btn-default" id="toggleDeploymentArtifactsVisibility" onclick="showOrHideDeploymentArtifacts(!$(this).hasClass('active'));">Deployment Artifacts</button>
	<button class="btn btn-default" id="toggleReqCapsVisibility" onclick="showOrHideReqCaps(!$(this).hasClass('active'));">Requirements &amp; Capabilities</button>
	<button class="btn btn-default" id="PoliciesVisibility" onclick="showOrHidePolicies(!$(this).hasClass('active'));">Policies</button>
</div>