system-clients 3.1.89-20 → 3.1.89-20-rongchuang-1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (199) hide show
  1. package/.babelrc +5 -5
  2. package/.editorconfig +9 -9
  3. package/.eslintrc.js +16 -16
  4. package/.gradle/6.8/executionHistory/executionHistory.bin +0 -0
  5. package/.gradle/6.8/executionHistory/executionHistory.lock +0 -0
  6. package/.gradle/6.8/fileChanges/last-build.bin +0 -0
  7. package/.gradle/6.8/fileHashes/fileHashes.bin +0 -0
  8. package/.gradle/6.8/fileHashes/fileHashes.lock +0 -0
  9. package/.gradle/{buildOutputCleanup/built.bin → 6.8/gc.properties} +0 -0
  10. package/.gradle/buildOutputCleanup/buildOutputCleanup.lock +0 -0
  11. package/.gradle/buildOutputCleanup/cache.properties +2 -2
  12. package/.gradle/buildOutputCleanup/outputFiles.bin +0 -0
  13. package/.gradle/checksums/checksums.lock +0 -0
  14. package/.gradle/configuration-cache/gc.properties +0 -0
  15. package/CHANGELOG.md +51 -51
  16. package/README.md +36 -36
  17. package/SystemClient.iml +11 -11
  18. package/build/css-loaders.js +34 -34
  19. package/build/dev-client.js +8 -8
  20. package/build/example-server.js +80 -80
  21. package/build/release.sh +28 -28
  22. package/build/utils.js +71 -71
  23. package/build/webpack.base.conf.js +75 -75
  24. package/build/webpack.dev.conf.js +31 -31
  25. package/build/webpack.example.conf.js +49 -49
  26. package/build/webpack.prod.conf.js +60 -60
  27. package/build/webpack.test.conf.js +31 -31
  28. package/build.gradle +6 -6
  29. package/config/dev.env.js +6 -6
  30. package/config/index.js +38 -38
  31. package/config/prod.env.js +3 -3
  32. package/config/test.env.js +6 -6
  33. package/doc/Login.md +7 -7
  34. package/examples/ReadCard/App.vue +23 -23
  35. package/examples/ReadCard/index.html +11 -11
  36. package/examples/ReadCard/main.js +12 -12
  37. package/gradle/wrapper/gradle-wrapper.jar +0 -0
  38. package/gradle/wrapper/gradle-wrapper.properties +5 -0
  39. package/gradlew +185 -0
  40. package/gradlew.bat +89 -0
  41. package/index.html +21 -21
  42. package/package.json +1 -1
  43. package/release.bat +5 -5
  44. package/src/App.vue +24 -24
  45. package/src/LodopFuncs.js +123 -123
  46. package/src/assets/binding.svg +1 -1
  47. package/src/assets/unbind.svg +1 -1
  48. package/src/assets//345/205/254/345/221/212.svg +1 -1
  49. package/src/assets//347/207/203/346/260/224/347/274/264/350/264/271.eps +116 -116
  50. package/src/assets//350/201/224/347/263/273/346/210/221/344/273/254.svg +1 -1
  51. package/src/components/List.vue +51 -51
  52. package/src/components/Main.vue +676 -589
  53. package/src/components/Table.js +74 -74
  54. package/src/components/Util.js +343 -343
  55. package/src/components/equipment/EquipmentManage.vue +65 -65
  56. package/src/components/equipment/PcAdd.vue +105 -105
  57. package/src/components/equipment/PcList.vue +119 -119
  58. package/src/components/equipment/PcManage.vue +60 -60
  59. package/src/components/equipment/PhoneAdd.vue +94 -94
  60. package/src/components/equipment/PhoneList.vue +102 -102
  61. package/src/components/equipment/PhoneManage.vue +60 -60
  62. package/src/components/equipment/PosAdd.vue +299 -299
  63. package/src/components/equipment/PosList.vue +254 -254
  64. package/src/components/equipment/PosManage.vue +150 -150
  65. package/src/components/materialManage/materialData.vue +44 -44
  66. package/src/components/materialManage/materialList.vue +255 -255
  67. package/src/components/parammanage/ParamManage.vue +42 -42
  68. package/src/components/parammanage/ParamManages.vue +43 -43
  69. package/src/components/parammanage/ParamPages.vue +222 -222
  70. package/src/components/parammanage/SinglePages.vue +167 -167
  71. package/src/components/server/AddChangeMsg.vue +66 -66
  72. package/src/components/server/ChangeDeclare.vue +45 -45
  73. package/src/components/server/IconTree.vue +26 -26
  74. package/src/components/server/ImageVieweTest.vue +56 -56
  75. package/src/components/server/ImageViewer.vue +350 -350
  76. package/src/components/server/LeftTree.vue +111 -111
  77. package/src/components/server/LoadData.vue +36 -36
  78. package/src/components/server/Menu.vue +188 -188
  79. package/src/components/server/ModifyPw.vue +106 -106
  80. package/src/components/server/ResSelect.vue +155 -155
  81. package/src/components/server/ResSelectGroup.vue +196 -196
  82. package/src/components/server/RightTree.vue +348 -348
  83. package/src/components/server/RoleSelector.vue +88 -88
  84. package/src/components/server/TestResSelect.vue +58 -58
  85. package/src/components/server/TestResSelectGroup.vue +388 -388
  86. package/src/components/server/TestRightTree.vue +42 -42
  87. package/src/index.js +7 -7
  88. package/src/plugins/GetLoginInfoService.js +4 -2
  89. package/src/plugins/HeatGetLoginInfoService.js +491 -491
  90. package/src/plugins/validation.js +7 -7
  91. package/src/project/ProjectPage.vue +24 -24
  92. package/src/project/State.js +17 -17
  93. package/src/stores/AppData.js +38 -38
  94. package/src/stores/HeatAppData.js +38 -38
  95. package/src/styles/fonts/glyphicons-halflings-regular.svg +287 -287
  96. package/src/styles/less/.csscomb.json +304 -304
  97. package/src/styles/less/.csslintrc +19 -19
  98. package/src/styles/less/alerts.less +73 -73
  99. package/src/styles/less/aofeng/animate.min.css +10 -10
  100. package/src/styles/less/aofeng/expandcss.less +569 -569
  101. package/src/styles/less/aofeng/themeOne/loginStyle.less +1586 -1586
  102. package/src/styles/less/aofeng/themeOne/systemStyle.less +2650 -2650
  103. package/src/styles/less/aofeng/themeOne.less +17 -17
  104. package/src/styles/less/aofeng/themeTwo/newStyle1.less +415 -415
  105. package/src/styles/less/aofeng/themeTwo.less +3 -3
  106. package/src/styles/less/badges.less +66 -66
  107. package/src/styles/less/bootstrap.less +66 -66
  108. package/src/styles/less/breadcrumbs.less +26 -26
  109. package/src/styles/less/button-groups.less +247 -247
  110. package/src/styles/less/buttons.less +172 -172
  111. package/src/styles/less/carousel.less +269 -269
  112. package/src/styles/less/close.less +34 -34
  113. package/src/styles/less/code.less +69 -69
  114. package/src/styles/less/component-animations.less +33 -33
  115. package/src/styles/less/dropdowns.less +216 -216
  116. package/src/styles/less/fonts-list.less +25 -25
  117. package/src/styles/less/forms.less +626 -626
  118. package/src/styles/less/glyphicons.less +305 -305
  119. package/src/styles/less/grid.less +84 -84
  120. package/src/styles/less/input-groups.less +167 -167
  121. package/src/styles/less/jumbotron.less +52 -52
  122. package/src/styles/less/labels.less +64 -64
  123. package/src/styles/less/list-group.less +141 -141
  124. package/src/styles/less/manageStyle/manageChile.less +180 -180
  125. package/src/styles/less/manageStyle/manageStyle.less +1102 -1102
  126. package/src/styles/less/manageStyle/safeStyle.less +498 -498
  127. package/src/styles/less/media.less +66 -66
  128. package/src/styles/less/mixins/alerts.less +14 -14
  129. package/src/styles/less/mixins/background-variant.less +9 -9
  130. package/src/styles/less/mixins/border-radius.less +18 -18
  131. package/src/styles/less/mixins/buttons.less +69 -69
  132. package/src/styles/less/mixins/center-block.less +7 -7
  133. package/src/styles/less/mixins/clearfix.less +22 -22
  134. package/src/styles/less/mixins/forms.less +90 -90
  135. package/src/styles/less/mixins/gradients.less +59 -59
  136. package/src/styles/less/mixins/grid-framework.less +92 -92
  137. package/src/styles/less/mixins/grid.less +122 -122
  138. package/src/styles/less/mixins/hide-text.less +21 -21
  139. package/src/styles/less/mixins/image.less +33 -33
  140. package/src/styles/less/mixins/labels.less +12 -12
  141. package/src/styles/less/mixins/list-group.less +30 -30
  142. package/src/styles/less/mixins/nav-divider.less +10 -10
  143. package/src/styles/less/mixins/nav-vertical-align.less +9 -9
  144. package/src/styles/less/mixins/opacity.less +8 -8
  145. package/src/styles/less/mixins/pagination.less +24 -24
  146. package/src/styles/less/mixins/panels.less +24 -24
  147. package/src/styles/less/mixins/progress-bar.less +10 -10
  148. package/src/styles/less/mixins/reset-filter.less +8 -8
  149. package/src/styles/less/mixins/reset-text.less +18 -18
  150. package/src/styles/less/mixins/resize.less +6 -6
  151. package/src/styles/less/mixins/responsive-visibility.less +15 -15
  152. package/src/styles/less/mixins/size.less +10 -10
  153. package/src/styles/less/mixins/tab-focus.less +9 -9
  154. package/src/styles/less/mixins/table-row.less +44 -44
  155. package/src/styles/less/mixins/text-emphasis.less +9 -9
  156. package/src/styles/less/mixins/text-overflow.less +8 -8
  157. package/src/styles/less/mixins/vendor-prefixes.less +227 -227
  158. package/src/styles/less/mixins.less +40 -40
  159. package/src/styles/less/modals.less +151 -151
  160. package/src/styles/less/navbar.less +660 -660
  161. package/src/styles/less/navs.less +285 -285
  162. package/src/styles/less/normalize.less +424 -424
  163. package/src/styles/less/pager.less +76 -76
  164. package/src/styles/less/pagination.less +89 -89
  165. package/src/styles/less/panels.less +275 -275
  166. package/src/styles/less/popovers.less +131 -131
  167. package/src/styles/less/print.less +101 -101
  168. package/src/styles/less/progress-bars.less +87 -87
  169. package/src/styles/less/responsive-embed.less +35 -35
  170. package/src/styles/less/responsive-utilities.less +194 -194
  171. package/src/styles/less/scaffolding.less +161 -161
  172. package/src/styles/less/stand.less +207 -207
  173. package/src/styles/less/theme.less +291 -291
  174. package/src/styles/less/thumbnails.less +36 -36
  175. package/src/styles/less/tooltip.less +102 -102
  176. package/src/styles/less/utilities.less +55 -55
  177. package/src/styles/less/wells.less +29 -29
  178. package/src/system.js +87 -87
  179. package/src/systemphone.js +11 -11
  180. package/src/util/LdapHelper.js +75 -75
  181. package/test/e2e/custom-assertions/elementCount.js +26 -26
  182. package/test/e2e/nightwatch.conf.js +40 -40
  183. package/test/e2e/runner.js +30 -30
  184. package/test/e2e/specs/test.js +14 -14
  185. package/test/unit/.eslintrc +5 -5
  186. package/test/unit/index.js +13 -13
  187. package/test/unit/init.js +10 -10
  188. package/test/unit/karma.conf.js +49 -49
  189. package/test/unit/specs/base64.spec.js +5 -5
  190. package/test/unit/specs/components/parammanage/ParamPage.spec.js +20 -20
  191. package/test/unit/specs/components/parammanage/SinglePage.spec.js +20 -20
  192. package/test/unit/specs/components/server/LeftTree/App.vue +18 -18
  193. package/test/unit/specs/components/server/LeftTree/LeftTree.spec.js +22 -22
  194. package/test/unit/specs/components/server/LoadData.spec.js +24 -24
  195. package/test/unit/specs/components/server/Login.spec.js +61 -61
  196. package/test/unit/specs/components/server/RightTree.spec.js +50 -50
  197. package/test/unit/specs/plugins/GetLoginInfoService.spec.js +55 -55
  198. package/test/unit/test.html +76 -76
  199. package/.gradle/buildOutputCleanup/cache.properties.lock +0 -1
@@ -1,247 +1,247 @@
1
- //
2
- // Button groups
3
- // --------------------------------------------------
4
-
5
- // Make the div behave like a button
6
- .btn-group,
7
- .btn-group-vertical {
8
- position: relative;
9
- display: inline-block;
10
- vertical-align: middle; // match .btn alignment given font-size hack above
11
- > .btn {
12
- position: relative;
13
- float: left;
14
- // Bring the "active" button to the front
15
- &:hover,
16
- &:focus,
17
- &:active,
18
- &.active {
19
- z-index: 2;
20
- }
21
- }
22
- }
23
-
24
- // Prevent double borders when buttons are next to each other
25
- .btn-group {
26
- .btn + .btn,
27
- .btn + .btn-group,
28
- .btn-group + .btn,
29
- .btn-group + .btn-group {
30
- margin-left: -1px;
31
- }
32
- }
33
-
34
- // Optional: Group multiple button groups together for a toolbar
35
- .btn-toolbar {
36
- margin-left: -5px; // Offset the first child's margin
37
- &:extend(.clearfix all);
38
-
39
- .btn,
40
- .btn-group,
41
- .input-group {
42
- float: left;
43
- }
44
- > .btn,
45
- > .btn-group,
46
- > .input-group {
47
- margin-left: 5px;
48
- }
49
- }
50
-
51
- .btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {
52
- border-radius: 0;
53
- }
54
-
55
- // Set corners individual because sometimes a single button can be in a .btn-group and we need :first-child and :last-child to both match
56
- .btn-group > .btn:first-child {
57
- margin-left: 0;
58
- &:not(:last-child):not(.dropdown-toggle) {
59
- .border-right-radius(0);
60
- }
61
- }
62
- // Need .dropdown-toggle since :last-child doesn't apply given a .dropdown-menu immediately after it
63
- .btn-group > .btn:last-child:not(:first-child),
64
- .btn-group > .dropdown-toggle:not(:first-child) {
65
- .border-left-radius(0);
66
- }
67
-
68
- // Custom edits for including btn-groups within btn-groups (useful for including dropdown buttons within a btn-group)
69
- .btn-group > .btn-group {
70
- float: left;
71
- }
72
- .btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {
73
- border-radius: 0;
74
- }
75
- .btn-group > .btn-group:first-child:not(:last-child) {
76
- > .btn:last-child,
77
- > .dropdown-toggle {
78
- .border-right-radius(0);
79
- }
80
- }
81
- .btn-group > .btn-group:last-child:not(:first-child) > .btn:first-child {
82
- .border-left-radius(0);
83
- }
84
-
85
- // On active and open, don't show outline
86
- .btn-group .dropdown-toggle:active,
87
- .btn-group.open .dropdown-toggle {
88
- outline: 0;
89
- }
90
-
91
-
92
- // Sizing
93
- //
94
- // Remix the default button sizing classes into new ones for easier manipulation.
95
-
96
- .btn-group-xs > .btn { &:extend(.btn-xs); }
97
- .btn-group-sm > .btn { &:extend(.btn-sm); }
98
- .btn-group-lg > .btn { &:extend(.btn-lg); }
99
-
100
-
101
- // Split button dropdowns
102
- // ----------------------
103
-
104
- // Give the line between buttons some depth
105
- .btn-group > .btn + .dropdown-toggle {
106
- padding-left: 8px;
107
- padding-right: 8px;
108
- }
109
- .btn-group > .btn-lg + .dropdown-toggle {
110
- padding-left: 12px;
111
- padding-right: 12px;
112
- }
113
-
114
- // The clickable button for toggling the menu
115
- // Remove the gradient and set the same inset shadow as the :active state
116
- .btn-group.open .dropdown-toggle {
117
- .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));
118
-
119
- // Show no shadow for `.btn-link` since it has no other button styles.
120
- &.btn-link {
121
- .box-shadow(none);
122
- }
123
- }
124
-
125
-
126
- // Reposition the caret
127
- .btn .caret {
128
- margin-left: 0;
129
- }
130
- // Carets in other button sizes
131
- .btn-lg .caret {
132
- border-width: @caret-width-large @caret-width-large 0;
133
- border-bottom-width: 0;
134
- }
135
- // Upside down carets for .dropup
136
- .dropup .btn-lg .caret {
137
- border-width: 0 @caret-width-large @caret-width-large;
138
- }
139
-
140
-
141
- // Vertical button groups
142
- // ----------------------
143
-
144
- .btn-group-vertical {
145
- > .btn,
146
- > .btn-group,
147
- > .btn-group > .btn {
148
- display: block;
149
- float: none;
150
- width: 100%;
151
- max-width: 100%;
152
- }
153
-
154
- // Clear floats so dropdown menus can be properly placed
155
- > .btn-group {
156
- &:extend(.clearfix all);
157
- > .btn {
158
- float: none;
159
- }
160
- }
161
-
162
- > .btn + .btn,
163
- > .btn + .btn-group,
164
- > .btn-group + .btn,
165
- > .btn-group + .btn-group {
166
- margin-top: -1px;
167
- margin-left: 0;
168
- }
169
- }
170
-
171
- .btn-group-vertical > .btn {
172
- &:not(:first-child):not(:last-child) {
173
- border-radius: 0;
174
- }
175
- &:first-child:not(:last-child) {
176
- border-top-right-radius: @btn-border-radius-base;
177
- .border-bottom-radius(0);
178
- }
179
- &:last-child:not(:first-child) {
180
- border-bottom-left-radius: @btn-border-radius-base;
181
- .border-top-radius(0);
182
- }
183
- }
184
- .btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {
185
- border-radius: 0;
186
- }
187
- .btn-group-vertical > .btn-group:first-child:not(:last-child) {
188
- > .btn:last-child,
189
- > .dropdown-toggle {
190
- .border-bottom-radius(0);
191
- }
192
- }
193
- .btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child {
194
- .border-top-radius(0);
195
- }
196
-
197
-
198
- // Justified button groups
199
- // ----------------------
200
-
201
- .btn-group-justified {
202
- display: table;
203
- width: 100%;
204
- table-layout: fixed;
205
- border-collapse: separate;
206
- > .btn,
207
- > .btn-group {
208
- float: none;
209
- display: table-cell;
210
- width: 1%;
211
- }
212
- > .btn-group .btn {
213
- width: 100%;
214
- }
215
-
216
- > .btn-group .dropdown-menu {
217
- left: auto;
218
- }
219
- }
220
-
221
- .btn-group .btn {
222
- margin-bottom: 0px;
223
- }
224
-
225
- // Checkbox and radio options
226
- //
227
- // In order to support the browser's form validation feedback, powered by the
228
- // `required` attribute, we have to "hide" the inputs via `clip`. We cannot use
229
- // `display: none;` or `visibility: hidden;` as that also hides the popover.
230
- // Simply visually hiding the inputs via `opacity` would leave them clickable in
231
- // certain cases which is prevented by using `clip` and `pointer-events`.
232
- // This way, we ensure a DOM element is visible to position the popover from.
233
- //
234
- // See https://github.com/twbs/bootstrap/pull/12794 and
235
- // https://github.com/twbs/bootstrap/pull/14559 for more information.
236
-
237
- [data-toggle="buttons"] {
238
- > .btn,
239
- > .btn-group > .btn {
240
- input[type="radio"],
241
- input[type="checkbox"] {
242
- position: absolute;
243
- clip: rect(0,0,0,0);
244
- pointer-events: none;
245
- }
246
- }
247
- }
1
+ //
2
+ // Button groups
3
+ // --------------------------------------------------
4
+
5
+ // Make the div behave like a button
6
+ .btn-group,
7
+ .btn-group-vertical {
8
+ position: relative;
9
+ display: inline-block;
10
+ vertical-align: middle; // match .btn alignment given font-size hack above
11
+ > .btn {
12
+ position: relative;
13
+ float: left;
14
+ // Bring the "active" button to the front
15
+ &:hover,
16
+ &:focus,
17
+ &:active,
18
+ &.active {
19
+ z-index: 2;
20
+ }
21
+ }
22
+ }
23
+
24
+ // Prevent double borders when buttons are next to each other
25
+ .btn-group {
26
+ .btn + .btn,
27
+ .btn + .btn-group,
28
+ .btn-group + .btn,
29
+ .btn-group + .btn-group {
30
+ margin-left: -1px;
31
+ }
32
+ }
33
+
34
+ // Optional: Group multiple button groups together for a toolbar
35
+ .btn-toolbar {
36
+ margin-left: -5px; // Offset the first child's margin
37
+ &:extend(.clearfix all);
38
+
39
+ .btn,
40
+ .btn-group,
41
+ .input-group {
42
+ float: left;
43
+ }
44
+ > .btn,
45
+ > .btn-group,
46
+ > .input-group {
47
+ margin-left: 5px;
48
+ }
49
+ }
50
+
51
+ .btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {
52
+ border-radius: 0;
53
+ }
54
+
55
+ // Set corners individual because sometimes a single button can be in a .btn-group and we need :first-child and :last-child to both match
56
+ .btn-group > .btn:first-child {
57
+ margin-left: 0;
58
+ &:not(:last-child):not(.dropdown-toggle) {
59
+ .border-right-radius(0);
60
+ }
61
+ }
62
+ // Need .dropdown-toggle since :last-child doesn't apply given a .dropdown-menu immediately after it
63
+ .btn-group > .btn:last-child:not(:first-child),
64
+ .btn-group > .dropdown-toggle:not(:first-child) {
65
+ .border-left-radius(0);
66
+ }
67
+
68
+ // Custom edits for including btn-groups within btn-groups (useful for including dropdown buttons within a btn-group)
69
+ .btn-group > .btn-group {
70
+ float: left;
71
+ }
72
+ .btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {
73
+ border-radius: 0;
74
+ }
75
+ .btn-group > .btn-group:first-child:not(:last-child) {
76
+ > .btn:last-child,
77
+ > .dropdown-toggle {
78
+ .border-right-radius(0);
79
+ }
80
+ }
81
+ .btn-group > .btn-group:last-child:not(:first-child) > .btn:first-child {
82
+ .border-left-radius(0);
83
+ }
84
+
85
+ // On active and open, don't show outline
86
+ .btn-group .dropdown-toggle:active,
87
+ .btn-group.open .dropdown-toggle {
88
+ outline: 0;
89
+ }
90
+
91
+
92
+ // Sizing
93
+ //
94
+ // Remix the default button sizing classes into new ones for easier manipulation.
95
+
96
+ .btn-group-xs > .btn { &:extend(.btn-xs); }
97
+ .btn-group-sm > .btn { &:extend(.btn-sm); }
98
+ .btn-group-lg > .btn { &:extend(.btn-lg); }
99
+
100
+
101
+ // Split button dropdowns
102
+ // ----------------------
103
+
104
+ // Give the line between buttons some depth
105
+ .btn-group > .btn + .dropdown-toggle {
106
+ padding-left: 8px;
107
+ padding-right: 8px;
108
+ }
109
+ .btn-group > .btn-lg + .dropdown-toggle {
110
+ padding-left: 12px;
111
+ padding-right: 12px;
112
+ }
113
+
114
+ // The clickable button for toggling the menu
115
+ // Remove the gradient and set the same inset shadow as the :active state
116
+ .btn-group.open .dropdown-toggle {
117
+ .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));
118
+
119
+ // Show no shadow for `.btn-link` since it has no other button styles.
120
+ &.btn-link {
121
+ .box-shadow(none);
122
+ }
123
+ }
124
+
125
+
126
+ // Reposition the caret
127
+ .btn .caret {
128
+ margin-left: 0;
129
+ }
130
+ // Carets in other button sizes
131
+ .btn-lg .caret {
132
+ border-width: @caret-width-large @caret-width-large 0;
133
+ border-bottom-width: 0;
134
+ }
135
+ // Upside down carets for .dropup
136
+ .dropup .btn-lg .caret {
137
+ border-width: 0 @caret-width-large @caret-width-large;
138
+ }
139
+
140
+
141
+ // Vertical button groups
142
+ // ----------------------
143
+
144
+ .btn-group-vertical {
145
+ > .btn,
146
+ > .btn-group,
147
+ > .btn-group > .btn {
148
+ display: block;
149
+ float: none;
150
+ width: 100%;
151
+ max-width: 100%;
152
+ }
153
+
154
+ // Clear floats so dropdown menus can be properly placed
155
+ > .btn-group {
156
+ &:extend(.clearfix all);
157
+ > .btn {
158
+ float: none;
159
+ }
160
+ }
161
+
162
+ > .btn + .btn,
163
+ > .btn + .btn-group,
164
+ > .btn-group + .btn,
165
+ > .btn-group + .btn-group {
166
+ margin-top: -1px;
167
+ margin-left: 0;
168
+ }
169
+ }
170
+
171
+ .btn-group-vertical > .btn {
172
+ &:not(:first-child):not(:last-child) {
173
+ border-radius: 0;
174
+ }
175
+ &:first-child:not(:last-child) {
176
+ border-top-right-radius: @btn-border-radius-base;
177
+ .border-bottom-radius(0);
178
+ }
179
+ &:last-child:not(:first-child) {
180
+ border-bottom-left-radius: @btn-border-radius-base;
181
+ .border-top-radius(0);
182
+ }
183
+ }
184
+ .btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {
185
+ border-radius: 0;
186
+ }
187
+ .btn-group-vertical > .btn-group:first-child:not(:last-child) {
188
+ > .btn:last-child,
189
+ > .dropdown-toggle {
190
+ .border-bottom-radius(0);
191
+ }
192
+ }
193
+ .btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child {
194
+ .border-top-radius(0);
195
+ }
196
+
197
+
198
+ // Justified button groups
199
+ // ----------------------
200
+
201
+ .btn-group-justified {
202
+ display: table;
203
+ width: 100%;
204
+ table-layout: fixed;
205
+ border-collapse: separate;
206
+ > .btn,
207
+ > .btn-group {
208
+ float: none;
209
+ display: table-cell;
210
+ width: 1%;
211
+ }
212
+ > .btn-group .btn {
213
+ width: 100%;
214
+ }
215
+
216
+ > .btn-group .dropdown-menu {
217
+ left: auto;
218
+ }
219
+ }
220
+
221
+ .btn-group .btn {
222
+ margin-bottom: 0px;
223
+ }
224
+
225
+ // Checkbox and radio options
226
+ //
227
+ // In order to support the browser's form validation feedback, powered by the
228
+ // `required` attribute, we have to "hide" the inputs via `clip`. We cannot use
229
+ // `display: none;` or `visibility: hidden;` as that also hides the popover.
230
+ // Simply visually hiding the inputs via `opacity` would leave them clickable in
231
+ // certain cases which is prevented by using `clip` and `pointer-events`.
232
+ // This way, we ensure a DOM element is visible to position the popover from.
233
+ //
234
+ // See https://github.com/twbs/bootstrap/pull/12794 and
235
+ // https://github.com/twbs/bootstrap/pull/14559 for more information.
236
+
237
+ [data-toggle="buttons"] {
238
+ > .btn,
239
+ > .btn-group > .btn {
240
+ input[type="radio"],
241
+ input[type="checkbox"] {
242
+ position: absolute;
243
+ clip: rect(0,0,0,0);
244
+ pointer-events: none;
245
+ }
246
+ }
247
+ }