forked from predixdesignsystem/px-dropdown
-
Notifications
You must be signed in to change notification settings - Fork 0
/
px-dropdown-chevron.html
112 lines (105 loc) · 2.94 KB
/
px-dropdown-chevron.html
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
<!--
Relative paths assume component is being run from inside an app or another component, where dependencies are flat
siblings. When this component is run from its own repo (e.g. ui tests, examples), we assume the server is started with
'grunt depserve' (or similar server setup) to enable correct finding of bower dependencies for local runs
-->
<link rel="import" href="../polymer/polymer.html" />
<link rel="import" href="../px-polymer-font-awesome/polymer-font-awesome.html" />
<!--
Element providing a chevron for the px-dropdown element.
##### Usage
```
<px-dropdown-chevron class="px-dropdown-chevron"></px-dropdown-chevron>
```
@element px-dropdown-chevron
@blurb Element which, when clicked, opens the px-dropdown-content element.
@homepage index.html
@demo demo.html
-->
<link rel="import" href="css/px-dropdown-chevron-styles.html">
<dom-module id="px-dropdown-chevron">
<template>
<style include="px-dropdown-chevron-styles"></style>
<div class$="{{_chevronClass(hover, opened)}} px-dropdown-chevron" id="trigger">
<iron-icon icon="fa:fa-angle-down" class$="{{_chevronClass(hover, opened)}} angle-down"></iron-icon>
</div>
</template>
</dom-module>
<script>
Polymer({
is: 'px-dropdown-chevron',
properties:{
/**
* Boolean which reflects whether the chevron is being hovered over.
*
* @prop hover
* @type Boolean
* @default false
* @notify true
*/
hover: {
type: Boolean,
value: false,
notify: true
},
/**
* Boolean which reflects whether the menu is open.
*
* @prop opened
* @type Boolean
* @default false
* @notify true
*/
opened: {
type: Boolean,
value: false,
notify: true
}
},
listeners: {
'hoverOff': '_manipulateHoverOff',
'hoverOn': '_manipulateHoverOn',
'opened': '_manipulateOpened'
},
/**
* this function flips the opened flag, and changes the class for the component
*
*
* @method _manipulateOpened
*/
_manipulateOpened: function(evt) {
evt.stopPropagation();
this.opened = !this.opened;
},
/**
* this function sets the hover flag to false, and changes the class for the component
*
* @method _manipulateHoverOff
*/
_manipulateHoverOff: function(evt) {
evt.stopPropagation();
this.hover = false;
},
/**
* this function sets the hover flag to true, and changes the class for the component
*
* @method _manipulateHoverOn
*/
_manipulateHoverOn: function(evt) {
evt.stopPropagation();
this.hover = true;
},
/**
* This method add either the opened or hover class.
*
* @method _chevronClass
*/
_chevronClass: function() {
if (this.opened) {
return "opened";
} else if (this.hover) {
return "hover";
}
}
});
</script>