Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
B
bootstrap-multiselect
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
bootstrap-multiselect
Commits
8ed8c4d0
Commit
8ed8c4d0
authored
Apr 20, 2016
by
David Stutz
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Updated tests and fixed select all + clickable + collapsible issues.
parent
3a5c6069
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
141 additions
and
101 deletions
+141
-101
bootstrap-multiselect.js
dist/js/bootstrap-multiselect.js
+100
-96
index.html
index.html
+33
-0
bootstrap-multiselect.js
tests/spec/bootstrap-multiselect.js
+8
-5
No files found.
dist/js/bootstrap-multiselect.js
View file @
8ed8c4d0
...
...
@@ -193,6 +193,7 @@
this
.
options
.
multiple
=
this
.
$select
.
attr
(
'
multiple
'
)
===
"
multiple
"
;
this
.
options
.
onChange
=
$
.
proxy
(
this
.
options
.
onChange
,
this
);
this
.
options
.
onSelectAll
=
$
.
proxy
(
this
.
options
.
onSelectAll
,
this
);
this
.
options
.
onDeselectAll
=
$
.
proxy
(
this
.
options
.
onDeselectAll
,
this
);
this
.
options
.
onDropdownShow
=
$
.
proxy
(
this
.
options
.
onDropdownShow
,
this
);
this
.
options
.
onDropdownHide
=
$
.
proxy
(
this
.
options
.
onDropdownHide
,
this
);
this
.
options
.
onDropdownShown
=
$
.
proxy
(
this
.
options
.
onDropdownShown
,
this
);
...
...
@@ -356,7 +357,13 @@
/**
* Triggered on select all.
*/
onSelectAll
:
function
(
checked
)
{
onSelectAll
:
function
()
{
},
/**
* Triggered on deselect all.
*/
onDeselectAll
:
function
()
{
},
/**
...
...
@@ -565,6 +572,7 @@
var
$checkboxesNotThis
=
$
(
'
input
'
,
this
.
$container
).
not
(
$target
);
if
(
isSelectAllOption
)
{
if
(
checked
)
{
this
.
selectAll
(
this
.
options
.
selectAllJustVisible
);
}
...
...
@@ -604,16 +612,17 @@
// To prevent select all from firing onChange: #575
this
.
options
.
onChange
(
$option
,
checked
);
}
this
.
$select
.
change
();
this
.
updateButtonText
();
// Do not update select all or optgroups on select all change!
this
.
updateSelectAll
();
if
(
this
.
options
.
enableClickableOptGroups
&&
this
.
options
.
multiple
)
{
this
.
updateOptGroup
(
$target
,
checked
);
this
.
updateOptGroups
(
);
}
}
this
.
$select
.
change
();
this
.
updateButtonText
();
if
(
this
.
options
.
preventInputChangeEvent
)
{
return
false
;
...
...
@@ -737,7 +746,10 @@
var
checked
=
$target
.
prop
(
'
checked
'
)
||
false
;
var
$li
=
$
(
event
.
target
).
closest
(
'
li
'
);
var
$group
=
$li
.
nextUntil
(
"
li.multiselect-group
"
).
filter
(
"
:visible:not(.disabled)
"
);
var
$group
=
$li
.
nextUntil
(
"
li.multiselect-group
"
)
.
not
(
'
.multiselect-filter-hidden
'
)
.
not
(
'
.disabled
'
);
var
$inputs
=
$group
.
find
(
"
input
"
);
var
values
=
[];
...
...
@@ -775,17 +787,24 @@
}
if
(
this
.
options
.
enableCollapsibleOptGroups
&&
this
.
options
.
multiple
)
{
//$("li.multiselect-group input", this.$ul).off();
$
(
"
li.multiselect-group
"
,
this
.
$ul
).
siblings
().
not
(
"
li.multiselect-group, li.multiselect-all
"
,
this
.
$ul
).
each
(
function
()
{
$
(
this
).
toggleClass
(
'
multiselect-collapsible-hidden
'
,
true
);
});
$
(
"
li.multiselect-group .caret-container
"
,
this
.
$ul
).
on
(
"
click
"
,
$
.
proxy
(
function
(
event
)
{
event
.
stopPropagation
();
var
$li
=
$
(
event
.
target
).
closest
(
'
li
'
);
var
$inputs
=
$li
.
nextUntil
(
"
li.multiselect-group
"
);
var
$inputs
=
$li
.
nextUntil
(
"
li.multiselect-group
"
)
.
not
(
'
.multiselect-filter-hidden
'
);
var
visible
=
true
;
$inputs
.
each
(
function
()
{
visible
=
visible
&&
$
(
this
).
is
(
'
:visible
'
);
});
$inputs
.
toggleClass
(
'
multiselect-collapsible-hidden
'
);
if
(
visible
)
{
$inputs
.
hide
()
.
addClass
(
'
multiselect-collapsible-hidden
'
);
}
else
{
$inputs
.
show
()
.
removeClass
(
'
multiselect-collapsible-hidden
'
);
}
},
this
));
$
(
"
li.multiselect-all
"
,
this
.
$ul
).
css
(
'
background
'
,
'
#f3f3f3
'
).
css
(
'
border-bottom
'
,
'
1px solid #eaeaea
'
);
...
...
@@ -974,7 +993,7 @@
$
(
'
input
'
,
this
.
$filter
).
attr
(
'
placeholder
'
,
this
.
options
.
filterPlaceholder
);
// Adds optional filter clear button
if
(
this
.
options
.
includeFilterClearBtn
){
if
(
this
.
options
.
includeFilterClearBtn
)
{
var
clearBtn
=
$
(
this
.
options
.
templates
.
filterClearBtn
);
clearBtn
.
on
(
'
click
'
,
$
.
proxy
(
function
(
event
){
clearTimeout
(
this
.
searchTimeout
);
...
...
@@ -1048,7 +1067,8 @@
}
// Toggle current element (group or group item) according to showElement boolean.
$
(
element
).
toggle
(
showElement
).
toggleClass
(
'
multiselect-filter-hidden
'
,
!
showElement
);
$
(
element
).
toggle
(
showElement
)
.
toggleClass
(
'
multiselect-filter-hidden
'
,
!
showElement
);
// Differentiate groups and group items.
if
(
$
(
element
).
hasClass
(
'
multiselect-group
'
))
{
...
...
@@ -1059,12 +1079,14 @@
else
{
// Show group name when at least one of its items is visible.
if
(
showElement
)
{
$
(
currentGroup
).
show
().
removeClass
(
'
multiselect-filter-hidden
'
);
$
(
currentGroup
).
show
()
.
removeClass
(
'
multiselect-filter-hidden
'
);
}
// Show all group items when group name satisfies filter.
if
(
!
showElement
&&
currentGroupVisible
)
{
$
(
element
).
show
().
removeClass
(
'
multiselect-filter-hidden
'
);
$
(
element
).
show
()
.
removeClass
(
'
multiselect-filter-hidden
'
);
}
}
}
...
...
@@ -1269,34 +1291,36 @@
* @param {Boolean} triggerOnSelectAll
*/
selectAll
:
function
(
justVisible
,
triggerOnSelectAll
)
{
justVisible
=
(
this
.
options
.
enableCollapsibleOptGroups
&&
this
.
options
.
multiple
)
?
false
:
justVisible
;
var
justVisible
=
typeof
justVisible
===
'
undefined
'
?
true
:
justVisible
;
var
allCheckboxes
=
$
(
"
li input[type='checkbox']:enabled
"
,
this
.
$ul
);
var
visibleCheckboxes
=
allCheckboxes
.
filter
(
"
:visible
"
);
var
allCheckboxesCount
=
allCheckboxes
.
length
;
var
visibleCheckboxesCount
=
visibleCheckboxes
.
length
;
var
allLis
=
$
(
"
li:not(.divider):not(.disabled):not(.multiselect-group)
"
,
this
.
$ul
);
var
visibleLis
=
$
(
"
li:not(.divider):not(.disabled):not(.multiselect-group):not(.multiselect-filter-hidden):not(.multiselect-collapisble-hidden)
"
,
this
.
$ul
).
filter
(
'
:visible
'
);
if
(
justVisible
)
{
visibleCheckboxes
.
prop
(
'
checked
'
,
true
);
$
(
"
li:not(.divider):not(.disabled):not(.multiselect-group)
"
,
this
.
$ul
).
filter
(
"
:visible
"
).
addClass
(
this
.
options
.
selectedClass
);
$
(
'
input:enabled
'
,
visibleLis
).
prop
(
'
checked
'
,
true
);
visibleLis
.
addClass
(
this
.
options
.
selectedClass
);
$
(
'
input:enabled
'
,
visibleLis
).
each
(
$
.
proxy
(
function
(
index
,
element
)
{
var
value
=
$
(
element
).
val
();
var
option
=
this
.
getOptionByValue
(
value
);
$
(
option
).
prop
(
'
selected
'
,
true
);
},
this
));
}
else
{
allCheckboxes
.
prop
(
'
checked
'
,
true
);
$
(
"
li:not(.divider):not(.disabled):not(.multiselect-group)
"
,
this
.
$ul
).
addClass
(
this
.
options
.
selectedClass
);
}
$
(
'
input:enabled
'
,
allLis
).
prop
(
'
checked
'
,
true
);
allLis
.
addClass
(
this
.
options
.
selectedClass
);
if
(
allCheckboxesCount
===
visibleCheckboxesCount
||
justVisible
===
false
)
{
$
(
"
option:not([data-role='divider']):enabled
"
,
this
.
$select
).
prop
(
'
selected
'
,
true
);
$
(
'
input:enabled
'
,
allLis
).
each
(
$
.
proxy
(
function
(
index
,
element
)
{
var
value
=
$
(
element
).
val
();
var
option
=
this
.
getOptionByValue
(
value
);
$
(
option
).
prop
(
'
selected
'
,
true
);
},
this
));
}
else
{
var
values
=
visibleCheckboxes
.
map
(
function
()
{
return
$
(
this
).
val
();
}).
get
();
$
(
"
option:enabled
"
,
this
.
$select
).
filter
(
function
(
index
)
{
return
$
.
inArray
(
$
(
this
).
val
(),
values
)
!==
-
1
;
}).
prop
(
'
selected
'
,
true
);
$
(
'
li input[value="
'
+
this
.
options
.
selectAllValue
+
'
"]
'
).
prop
(
'
checked
'
,
true
);
if
(
this
.
options
.
enableClickableOptGroups
&&
this
.
options
.
multiple
)
{
this
.
updateOptGroups
();
}
if
(
triggerOnSelectAll
)
{
...
...
@@ -1311,33 +1335,41 @@
*
* @param {Boolean} justVisible
*/
deselectAll
:
function
(
justVisible
)
{
justVisible
=
(
this
.
options
.
enableCollapsibleOptGroups
&&
this
.
options
.
multiple
)
?
false
:
justVisible
;
justVisible
=
typeof
justVisible
===
'
undefined
'
?
true
:
justVisible
;
deselectAll
:
function
(
justVisible
,
triggerOnDeselectAll
)
{
if
(
justVisible
)
{
var
visibleCheckboxes
=
$
(
"
li input[type='checkbox']:not(:disabled)
"
,
this
.
$ul
).
filter
(
"
:visible
"
);
visibleCheckboxes
.
prop
(
'
checked
'
,
false
);
var
values
=
visibleCheckboxes
.
map
(
function
()
{
return
$
(
this
).
val
();
}).
get
();
var
justVisible
=
typeof
justVisible
===
'
undefined
'
?
true
:
justVisible
;
var
allLis
=
$
(
"
li:not(.divider):not(.disabled):not(.multiselect-group)
"
,
this
.
$ul
);
var
visibleLis
=
$
(
"
li:not(.divider):not(.disabled):not(.multiselect-group):not(.multiselect-filter-hidden):not(.multiselect-collapisble-hidden)
"
,
this
.
$ul
).
filter
(
'
:visible
'
);
$
(
"
option:enabled
"
,
this
.
$select
).
filter
(
function
(
index
)
{
return
$
.
inArray
(
$
(
this
).
val
(),
values
)
!==
-
1
;
}).
prop
(
'
selected
'
,
false
);
if
(
justVisible
)
{
$
(
'
input[type="checkbox"]:enabled
'
,
visibleLis
).
prop
(
'
checked
'
,
false
)
;
visibleLis
.
removeClass
(
this
.
options
.
selectedClass
);
if
(
this
.
options
.
selectedClass
)
{
$
(
"
li:not(.divider):not(.disabled)
"
,
this
.
$ul
).
filter
(
"
:visible
"
).
removeClass
(
this
.
options
.
selectedClass
);
}
$
(
'
input[type="checkbox"]:enabled
'
,
visibleLis
).
each
(
$
.
proxy
(
function
(
index
,
element
)
{
var
value
=
$
(
element
).
val
();
var
option
=
this
.
getOptionByValue
(
value
);
$
(
option
).
prop
(
'
selected
'
,
false
);
},
this
));
}
else
{
$
(
"
li input[type='checkbox']:enabled
"
,
this
.
$ul
).
prop
(
'
checked
'
,
false
);
$
(
"
option:enabled
"
,
this
.
$select
).
prop
(
'
selected
'
,
false
);
$
(
'
input[type="checkbox"]:enabled
'
,
allLis
).
prop
(
'
checked
'
,
false
);
allLis
.
removeClass
(
this
.
options
.
selectedClass
);
if
(
this
.
options
.
selectedClass
)
{
$
(
"
li:not(.divider):not(.disabled)
"
,
this
.
$ul
).
removeClass
(
this
.
options
.
selectedClass
);
$
(
'
input[type="checkbox"]:enabled
'
,
allLis
).
each
(
$
.
proxy
(
function
(
index
,
element
)
{
var
value
=
$
(
element
).
val
();
var
option
=
this
.
getOptionByValue
(
value
);
$
(
option
).
prop
(
'
selected
'
,
false
);
},
this
));
}
$
(
'
li input[value="
'
+
this
.
options
.
selectAllValue
+
'
"]
'
).
prop
(
'
checked
'
,
false
);
if
(
this
.
options
.
enableClickableOptGroups
&&
this
.
options
.
multiple
)
{
this
.
updateOptGroups
();
}
if
(
triggerOnDeselectAll
)
{
this
.
options
.
onDeselectAll
();
}
},
...
...
@@ -1483,36 +1515,6 @@
return
$
(
'
li.multiselect-all
'
,
this
.
$ul
).
length
>
0
;
},
/**
* Update a particular opt group.
*/
updateOptGroup
:
function
(
$element
,
checked
)
{
var
$prevs
=
$element
.
closest
(
'
li
'
).
prevUntil
(
'
li.multiselect-group
'
).
filter
(
"
:visible:not(.disabled)
"
);
var
$nexts
=
$element
.
closest
(
'
li
'
).
nextUntil
(
'
li.multiselect-group
'
).
filter
(
"
:visible:not(.disabled)
"
);
var
selected
=
checked
;
$prevs
.
each
(
function
()
{
if
(
!
$
(
'
input
'
,
this
).
prop
(
'
checked
'
))
{
selected
=
false
;
}
});
$nexts
.
each
(
function
()
{
if
(
!
$
(
'
input
'
,
this
).
prop
(
'
checked
'
))
{
selected
=
false
;
}
});
var
$group
=
$element
.
closest
(
'
li
'
).
prevAll
(
'
li.multiselect-group
'
)[
0
];
if
(
selected
)
{
$
(
'
input
'
,
$group
).
prop
(
'
checked
'
,
true
);
}
else
{
$
(
'
input
'
,
$group
).
prop
(
'
checked
'
,
false
);
}
},
/**
* Update opt groups.
*/
...
...
@@ -1520,7 +1522,9 @@
var
$groups
=
$
(
'
li.multiselect-group
'
,
this
.
$ul
)
$groups
.
each
(
function
()
{
var
$options
=
$
(
this
).
nextUntil
(
'
li.multiselect-group
'
).
filter
(
"
:not(.disabled)
"
);
var
$options
=
$
(
this
).
nextUntil
(
'
li.multiselect-group
'
)
.
not
(
'
.multiselect-filter-hidden
'
)
.
not
(
'
.disabled
'
);
var
checked
=
true
;
$options
.
each
(
function
()
{
...
...
@@ -1540,7 +1544,7 @@
*/
updateSelectAll
:
function
(
notTriggerOnSelectAll
)
{
if
(
this
.
hasSelectAll
())
{
var
allBoxes
=
$
(
"
li:not(.multiselect-item):not(.multiselect-filter-hidden) input:enabled
"
,
this
.
$ul
);
var
allBoxes
=
$
(
"
li:not(.multiselect-item):not(.multiselect-filter-hidden)
:not(.multiselect-group):not(.disabled)
input:enabled
"
,
this
.
$ul
);
var
allBoxesLength
=
allBoxes
.
length
;
var
checkedBoxesLength
=
allBoxes
.
filter
(
"
:checked
"
).
length
;
var
selectAllLi
=
$
(
"
li.multiselect-all
"
,
this
.
$ul
);
...
...
index.html
View file @
8ed8c4d0
...
...
@@ -2322,6 +2322,39 @@
});
});
<
/script
>
</pre>
</div>
<p>
The select all element naturally respects disabled elements:
</p>
<div
class=
"example"
>
<script
type=
"text/javascript"
>
$
(
document
).
ready
(
function
()
{
$
(
'
#example-includeSelectAllOption-disbled
'
).
multiselect
({
includeSelectAllOption
:
true
});
});
</script>
<select
id=
"example-includeSelectAllOption-disbled"
multiple=
"multiple"
>
<option
value=
"1"
disabled=
"disabled"
>
Option 1
</option>
<option
value=
"2"
>
Option 2
</option>
<option
value=
"3"
>
Option 3
</option>
<option
value=
"4"
>
Option 4
</option>
<option
value=
"5"
>
Option 5
</option>
<option
value=
"6"
>
Option 6
</option>
</select>
</div>
<div
class=
"highlight"
>
<pre
class=
"prettyprint linenums"
>
<
script type="text/javascript"
>
$(document).ready(function() {
$('#example-includeSelectAllOption-disbled').multiselect({
includeSelectAllOption: true
});
});
<
/script
>
</pre>
</div>
</td>
...
...
tests/spec/bootstrap-multiselect.js
View file @
8ed8c4d0
...
...
@@ -516,14 +516,16 @@ describe('Bootstrap Multiselect "Collapsible Optgroups"', function() {
var
$lis
=
$group
.
nextUntil
(
'
li.multiselect-group
'
);
$lis
.
each
(
function
()
{
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
false
);
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
true
);
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
$
(
this
).
is
(
'
:hidden
'
));
});
$
(
'
.caret-container
'
,
$group
).
click
();
var
$lis
=
$group
.
nextUntil
(
'
li.multiselect-group
'
);
$lis
.
each
(
function
()
{
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
true
);
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
false
);
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
$
(
this
).
is
(
'
:hidden
'
));
});
});
...
...
@@ -616,14 +618,16 @@ describe('Bootstrap Multiselect "Clickable+Collapsible Optgroups"', function() {
var
$lis
=
$group
.
nextUntil
(
'
li.multiselect-group
'
);
$lis
.
each
(
function
()
{
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
false
);
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
true
);
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
$
(
this
).
is
(
'
:hidden
'
));
});
$
(
'
.caret-container
'
,
$group
).
click
();
var
$lis
=
$group
.
nextUntil
(
'
li.multiselect-group
'
);
$lis
.
each
(
function
()
{
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
true
);
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
false
);
expect
(
$
(
this
).
hasClass
(
'
multiselect-collapsible-hidden
'
)).
toBe
(
$
(
this
).
is
(
'
:hidden
'
));
});
});
...
...
@@ -664,7 +668,6 @@ describe('Bootstrap Multiselect "Clickable+Collapsible+SelectAll Optgroups"', fu
it
(
'
Should handle option groups differently, i.e. not set class to active.
'
,
function
()
{
// Otherwise they are hidden.
$
(
'
#multiselect-container li.multiselect-group .caret-container
'
).
click
();
$
(
'
#multiselect-container input[value="multiselect-all"]
'
).
click
();
var
$groups
=
$
(
'
#multiselect-container li.multiselect-group
'
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment