forked from PolymerEl/paper-tags
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpaper-tags-mixin.html
69 lines (63 loc) · 2.09 KB
/
paper-tags-mixin.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
<!--
@license
Copyright (c) 2015 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
-->
<link rel="import" href="../polymer/polymer.html">
<link rel="import" href="value-array-firebase-mixin.html">
<script>
/**
* `Polymer.PaperTagsMixin` defines recurent properties in paper-tags family (paper-tags, paper-tags-input, paper-tags-dropdown)
*
* @demo demo/index.html
*/
var PaperTagsMixin = function(superClass) {
return class extends ValueArrayFirebaseMixin(superClass) {
static get properties() {
return {
/**
* `itemClass` the class applied to tag items. If `classAccessor` is defined, `classAccessor` will have precedence
*/
itemClass: String,
/**
* `icon` icon to be applied to the tag item when it is not removable. If `iconAccessor` is defined, `iconAccessor` will have precedence
*/
icon: String,
/**
* `keyPath` key for retrieving the `id` from item data object
*/
keyPath: {
type: String,
value: 'id'
},
/**
* `labelPath` key for retrieving the `label` from item data object
*/
labelPath: {
type: String,
value: 'label'
},
/**
* `classPath` key for retrieving the `class` from item data object
*/
classPath: String,
/**
* `iconPath` key for retrieving the `icon` from item data object
*/
iconPath: String,
/**
* `preventRemoveTag` hide the `close` icon and prevent removing a tag when true.
*/
preventRemoveTag: {
type: Boolean,
value: false
}
};
}
};
}
</script>