system-clients 3.2.70 → 3.2.72-yc

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 (206) hide show
  1. package/.babelrc +5 -5
  2. package/.editorconfig +9 -9
  3. package/.eslintrc.js +16 -16
  4. package/CHANGELOG.md +51 -51
  5. package/README.md +36 -36
  6. package/SystemClient.iml +8 -8
  7. package/build/css-loaders.js +34 -34
  8. package/build/dev-client.js +8 -8
  9. package/build/example-server.js +80 -80
  10. package/build/release.sh +28 -28
  11. package/build/utils.js +71 -71
  12. package/build/webpack.base.conf.js +85 -85
  13. package/build/webpack.dev.conf.js +31 -31
  14. package/build/webpack.example.conf.js +49 -49
  15. package/build/webpack.prod.conf.js +60 -60
  16. package/build/webpack.test.conf.js +31 -31
  17. package/build.gradle +6 -6
  18. package/config/dev.env.js +6 -6
  19. package/config/index.js +38 -38
  20. package/config/prod.env.js +3 -3
  21. package/config/test.env.js +6 -6
  22. package/doc/Login.md +7 -7
  23. package/examples/LoginPage/App.vue +21 -21
  24. package/examples/LoginPage/index.html +11 -11
  25. package/examples/LoginPage/main.js +15 -15
  26. package/examples/ReadCard/App.vue +23 -23
  27. package/examples/ReadCard/index.html +11 -11
  28. package/examples/ReadCard/main.js +12 -12
  29. package/index.html +21 -21
  30. package/package.json +1 -1
  31. package/release.bat +5 -5
  32. package/src/App.vue +24 -24
  33. package/src/LodopFuncs.js +123 -123
  34. package/src/assets/binding.svg +1 -1
  35. package/src/assets/unbind.svg +1 -1
  36. package/src/assets//345/205/254/345/221/212.svg +1 -1
  37. package/src/assets//347/207/203/346/260/224/347/274/264/350/264/271.eps +116 -116
  38. package/src/assets//350/201/224/347/263/273/346/210/221/344/273/254.svg +1 -1
  39. package/src/components/List.vue +51 -51
  40. package/src/components/Main.vue +87 -11
  41. package/src/components/TabButton.vue +201 -201
  42. package/src/components/Table.js +74 -74
  43. package/src/components/Tabs.vue +67 -67
  44. package/src/components/Util.js +343 -343
  45. package/src/components/addressManage/AddressCascadingMenu.vue +145 -145
  46. package/src/components/common/ProgressBase.vue +83 -83
  47. package/src/components/equipment/PosManage.vue +138 -138
  48. package/src/components/equipment/PosManageBoth.vue +125 -125
  49. package/src/components/equipment/PosParamManage.vue +51 -51
  50. package/src/components/materialManage/materialData.vue +44 -44
  51. package/src/components/materialManage/materialList.vue +255 -255
  52. package/src/components/parammanage/ParamManage.vue +42 -42
  53. package/src/components/parammanage/ParamManages.vue +43 -43
  54. package/src/components/parammanage/ParamPages.vue +222 -222
  55. package/src/components/parammanage/SinglePages.vue +167 -167
  56. package/src/components/server/AddChangeMsg.vue +66 -66
  57. package/src/components/server/ChangeDeclare.vue +45 -45
  58. package/src/components/server/IconTree.vue +26 -26
  59. package/src/components/server/ImageVieweTest.vue +56 -56
  60. package/src/components/server/ImageViewer.vue +350 -350
  61. package/src/components/server/LeftTree.vue +111 -111
  62. package/src/components/server/LoadData.vue +56 -55
  63. package/src/components/server/LoginPage.vue +235 -235
  64. package/src/components/server/LoginView.vue +128 -128
  65. package/src/components/server/Menu.vue +188 -188
  66. package/src/components/server/TestResSelect.vue +58 -58
  67. package/src/components/server/TestResSelectGroup.vue +388 -388
  68. package/src/components/server/TestRightTree.vue +42 -42
  69. package/src/filiale/baole/system.js +5 -5
  70. package/src/filiale/chengtou/system.js +5 -5
  71. package/src/filiale/dongguan/system.js +6 -6
  72. package/src/filiale/furuike/system.js +7 -7
  73. package/src/filiale/gehua/system.js +6 -6
  74. package/src/filiale/qianneng/Login.vue +566 -0
  75. package/src/filiale/qianneng/ModifyPw.vue +2 -2
  76. package/src/filiale/qianneng/system.js +11 -8
  77. package/src/filiale/rizhao/LeftTree.vue +111 -111
  78. package/src/filiale/rizhao/system.js +14 -14
  79. package/src/filiale/shiquan/system.js +8 -8
  80. package/src/filiale/tianyi/system.js +5 -5
  81. package/src/filiale/wenxi/system.js +10 -10
  82. package/src/filiale/wuhai/LeftTree.vue +141 -141
  83. package/src/filiale/wuhai/system.js +10 -10
  84. package/src/filiale/yuchuan/system.js +10 -10
  85. package/src/filiale/zhoukou/system.js +6 -6
  86. package/src/index.js +7 -7
  87. package/src/plugins/EncryptUtil.js +53 -53
  88. package/src/plugins/HeatGetLoginInfoService.js +491 -491
  89. package/src/plugins/validation.js +1 -1
  90. package/src/project/ProjectPage.vue +24 -24
  91. package/src/project/State.js +17 -17
  92. package/src/stores/AppData.js +1 -1
  93. package/src/stores/HeatAppData.js +38 -38
  94. package/src/styles/fonts/glyphicons-halflings-regular.svg +288 -288
  95. package/src/styles/less/.csscomb.json +304 -304
  96. package/src/styles/less/.csslintrc +19 -19
  97. package/src/styles/less/alerts.less +73 -73
  98. package/src/styles/less/aofeng/animate.min.css +10 -10
  99. package/src/styles/less/aofeng/expandcss.less +569 -569
  100. package/src/styles/less/aofeng/login.less +367 -367
  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/manageChile.less +180 -180
  126. package/src/styles/less/manageStyle/manageStyle/manageStyle.less +1102 -1102
  127. package/src/styles/less/manageStyle/manageStyle/safeStyle.less +498 -498
  128. package/src/styles/less/manageStyle/manageStyle.less +1102 -1102
  129. package/src/styles/less/manageStyle/safeStyle.less +498 -498
  130. package/src/styles/less/media.less +66 -66
  131. package/src/styles/less/mixins/alerts.less +14 -14
  132. package/src/styles/less/mixins/background-variant.less +9 -9
  133. package/src/styles/less/mixins/border-radius.less +18 -18
  134. package/src/styles/less/mixins/buttons.less +69 -69
  135. package/src/styles/less/mixins/center-block.less +7 -7
  136. package/src/styles/less/mixins/clearfix.less +22 -22
  137. package/src/styles/less/mixins/forms.less +90 -90
  138. package/src/styles/less/mixins/gradients.less +59 -59
  139. package/src/styles/less/mixins/grid-framework.less +92 -92
  140. package/src/styles/less/mixins/grid.less +122 -122
  141. package/src/styles/less/mixins/hide-text.less +21 -21
  142. package/src/styles/less/mixins/image.less +33 -33
  143. package/src/styles/less/mixins/labels.less +12 -12
  144. package/src/styles/less/mixins/list-group.less +30 -30
  145. package/src/styles/less/mixins/nav-divider.less +10 -10
  146. package/src/styles/less/mixins/nav-vertical-align.less +9 -9
  147. package/src/styles/less/mixins/opacity.less +8 -8
  148. package/src/styles/less/mixins/pagination.less +24 -24
  149. package/src/styles/less/mixins/panels.less +24 -24
  150. package/src/styles/less/mixins/progress-bar.less +10 -10
  151. package/src/styles/less/mixins/reset-filter.less +8 -8
  152. package/src/styles/less/mixins/reset-text.less +18 -18
  153. package/src/styles/less/mixins/resize.less +6 -6
  154. package/src/styles/less/mixins/responsive-visibility.less +15 -15
  155. package/src/styles/less/mixins/size.less +10 -10
  156. package/src/styles/less/mixins/tab-focus.less +9 -9
  157. package/src/styles/less/mixins/table-row.less +44 -44
  158. package/src/styles/less/mixins/text-emphasis.less +9 -9
  159. package/src/styles/less/mixins/text-overflow.less +8 -8
  160. package/src/styles/less/mixins/vendor-prefixes.less +227 -227
  161. package/src/styles/less/mixins.less +40 -40
  162. package/src/styles/less/modals.less +151 -151
  163. package/src/styles/less/navbar.less +660 -660
  164. package/src/styles/less/navs.less +285 -285
  165. package/src/styles/less/normalize.less +424 -424
  166. package/src/styles/less/pager.less +76 -76
  167. package/src/styles/less/pagination.less +89 -89
  168. package/src/styles/less/panels.less +275 -275
  169. package/src/styles/less/popovers.less +131 -131
  170. package/src/styles/less/print.less +101 -101
  171. package/src/styles/less/progress-bars.less +87 -87
  172. package/src/styles/less/responsive-embed.less +35 -35
  173. package/src/styles/less/responsive-utilities.less +194 -194
  174. package/src/styles/less/scaffolding.less +161 -161
  175. package/src/styles/less/stand.less +207 -207
  176. package/src/styles/less/tables.less +312 -312
  177. package/src/styles/less/theme.less +291 -291
  178. package/src/styles/less/thumbnails.less +36 -36
  179. package/src/styles/less/tooltip.less +102 -102
  180. package/src/styles/less/type.less +316 -316
  181. package/src/styles/less/utilities.less +55 -55
  182. package/src/styles/less/variables.less +899 -899
  183. package/src/styles/less/wells.less +29 -29
  184. package/src/system.js +121 -121
  185. package/src/systemphone.js +11 -11
  186. package/src/util/Daiban.json +12 -12
  187. package/src/util/LdapHelper.js +75 -75
  188. package/test/e2e/custom-assertions/elementCount.js +26 -26
  189. package/test/e2e/nightwatch.conf.js +40 -40
  190. package/test/e2e/runner.js +30 -30
  191. package/test/e2e/specs/test.js +14 -14
  192. package/test/unit/.eslintrc +5 -5
  193. package/test/unit/index.js +13 -13
  194. package/test/unit/init.js +10 -10
  195. package/test/unit/karma.conf.js +49 -49
  196. package/test/unit/specs/base64.spec.js +5 -5
  197. package/test/unit/specs/components/parammanage/ParamPage.spec.js +20 -20
  198. package/test/unit/specs/components/parammanage/SinglePage.spec.js +20 -20
  199. package/test/unit/specs/components/server/LeftTree/App.vue +18 -18
  200. package/test/unit/specs/components/server/LeftTree/LeftTree.spec.js +22 -22
  201. package/test/unit/specs/components/server/LoadData.spec.js +24 -24
  202. package/test/unit/specs/components/server/Login.spec.js +61 -61
  203. package/test/unit/specs/components/server/RightTree.spec.js +50 -50
  204. package/test/unit/specs/plugins/GetLoginInfoService.spec.js +55 -55
  205. package/test/unit/test.html +76 -76
  206. package/yarn-error.log +6896 -6896
@@ -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
+ }