system-phone 3.0.2 → 3.0.4-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 (271) hide show
  1. package/.babelrc +5 -5
  2. package/.editorconfig +9 -9
  3. package/.eslintrc.js +16 -16
  4. package/.gradle/6.8.3/fileChanges/last-build.bin +0 -0
  5. package/.gradle/6.8.3/fileHashes/fileHashes.lock +0 -0
  6. package/.gradle/6.8.3/gc.properties +0 -0
  7. package/.gradle/buildOutputCleanup/cache.properties +2 -2
  8. package/.gradle/checksums/checksums.lock +0 -0
  9. package/.gradle/checksums/md5-checksums.bin +0 -0
  10. package/.gradle/checksums/sha1-checksums.bin +0 -0
  11. package/.gradle/configuration-cache/gc.properties +0 -0
  12. package/CHANGELOG.md +1 -1
  13. package/Dockerfile +3 -3
  14. package/README.md +36 -36
  15. package/SystemPhone.iml +8 -8
  16. package/build/css-loaders.js +34 -34
  17. package/build/dev-client.js +8 -8
  18. package/build/dev-server.js +141 -141
  19. package/build/example-server.js +80 -80
  20. package/build/release.sh +28 -28
  21. package/build/utils.js +71 -71
  22. package/build/webpack.base.conf.js +82 -82
  23. package/build/webpack.dev.conf.js +31 -31
  24. package/build/webpack.example.conf.js +49 -49
  25. package/build/webpack.prod.conf.js +60 -60
  26. package/build/webpack.test.conf.js +31 -31
  27. package/build.gradle +27 -27
  28. package/config/dev.env.js +6 -6
  29. package/config/index.js +38 -38
  30. package/config/prod.env.js +3 -3
  31. package/config/test.env.js +6 -6
  32. package/gradle/wrapper/gradle-wrapper.properties +5 -5
  33. package/gradlew +183 -183
  34. package/gradlew.bat +100 -100
  35. package/index.html +21 -21
  36. package/nginx.conf +304 -304
  37. package/package.json +1 -1
  38. package/release.bat +5 -5
  39. package/src/App.vue +25 -25
  40. package/src/Util.js +415 -415
  41. package/src/android-bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  42. package/src/android-bootstrap/less/.csscomb.json +304 -304
  43. package/src/android-bootstrap/less/.csslintrc +19 -19
  44. package/src/android-bootstrap/less/alerts.less +73 -73
  45. package/src/android-bootstrap/less/badges.less +66 -66
  46. package/src/android-bootstrap/less/bootstrap.less +56 -56
  47. package/src/android-bootstrap/less/breadcrumbs.less +26 -26
  48. package/src/android-bootstrap/less/button-groups.less +247 -247
  49. package/src/android-bootstrap/less/buttons.less +173 -173
  50. package/src/android-bootstrap/less/carousel.less +269 -269
  51. package/src/android-bootstrap/less/close.less +34 -34
  52. package/src/android-bootstrap/less/code.less +69 -69
  53. package/src/android-bootstrap/less/component-animations.less +33 -33
  54. package/src/android-bootstrap/less/dropdowns.less +216 -216
  55. package/src/android-bootstrap/less/forms.less +626 -626
  56. package/src/android-bootstrap/less/glyphicons.less +305 -305
  57. package/src/android-bootstrap/less/grid.less +84 -84
  58. package/src/android-bootstrap/less/input-groups.less +167 -167
  59. package/src/android-bootstrap/less/jumbotron.less +52 -52
  60. package/src/android-bootstrap/less/labels.less +64 -64
  61. package/src/android-bootstrap/less/list-group.less +141 -141
  62. package/src/android-bootstrap/less/media.less +66 -66
  63. package/src/android-bootstrap/less/mixins/alerts.less +14 -14
  64. package/src/android-bootstrap/less/mixins/background-variant.less +9 -9
  65. package/src/android-bootstrap/less/mixins/border-radius.less +18 -18
  66. package/src/android-bootstrap/less/mixins/buttons.less +69 -69
  67. package/src/android-bootstrap/less/mixins/center-block.less +7 -7
  68. package/src/android-bootstrap/less/mixins/clearfix.less +22 -22
  69. package/src/android-bootstrap/less/mixins/forms.less +90 -90
  70. package/src/android-bootstrap/less/mixins/gradients.less +59 -59
  71. package/src/android-bootstrap/less/mixins/grid-framework.less +92 -92
  72. package/src/android-bootstrap/less/mixins/grid.less +122 -122
  73. package/src/android-bootstrap/less/mixins/hide-text.less +21 -21
  74. package/src/android-bootstrap/less/mixins/image.less +33 -33
  75. package/src/android-bootstrap/less/mixins/labels.less +12 -12
  76. package/src/android-bootstrap/less/mixins/list-group.less +30 -30
  77. package/src/android-bootstrap/less/mixins/nav-divider.less +10 -10
  78. package/src/android-bootstrap/less/mixins/nav-vertical-align.less +9 -9
  79. package/src/android-bootstrap/less/mixins/opacity.less +8 -8
  80. package/src/android-bootstrap/less/mixins/pagination.less +24 -24
  81. package/src/android-bootstrap/less/mixins/panels.less +24 -24
  82. package/src/android-bootstrap/less/mixins/progress-bar.less +10 -10
  83. package/src/android-bootstrap/less/mixins/reset-filter.less +8 -8
  84. package/src/android-bootstrap/less/mixins/reset-text.less +18 -18
  85. package/src/android-bootstrap/less/mixins/resize.less +6 -6
  86. package/src/android-bootstrap/less/mixins/responsive-visibility.less +15 -15
  87. package/src/android-bootstrap/less/mixins/size.less +10 -10
  88. package/src/android-bootstrap/less/mixins/tab-focus.less +9 -9
  89. package/src/android-bootstrap/less/mixins/table-row.less +44 -44
  90. package/src/android-bootstrap/less/mixins/text-emphasis.less +9 -9
  91. package/src/android-bootstrap/less/mixins/text-overflow.less +8 -8
  92. package/src/android-bootstrap/less/mixins/vendor-prefixes.less +227 -227
  93. package/src/android-bootstrap/less/mixins.less +40 -40
  94. package/src/android-bootstrap/less/modals.less +151 -151
  95. package/src/android-bootstrap/less/navbar.less +660 -660
  96. package/src/android-bootstrap/less/navs.less +290 -290
  97. package/src/android-bootstrap/less/normalize.less +424 -424
  98. package/src/android-bootstrap/less/pager.less +76 -76
  99. package/src/android-bootstrap/less/pagination.less +89 -89
  100. package/src/android-bootstrap/less/panels.less +274 -274
  101. package/src/android-bootstrap/less/popovers.less +131 -131
  102. package/src/android-bootstrap/less/print.less +101 -101
  103. package/src/android-bootstrap/less/progress-bars.less +87 -87
  104. package/src/android-bootstrap/less/responsive-embed.less +35 -35
  105. package/src/android-bootstrap/less/responsive-utilities.less +194 -194
  106. package/src/android-bootstrap/less/scaffolding.less +161 -161
  107. package/src/android-bootstrap/less/tables.less +262 -262
  108. package/src/android-bootstrap/less/theme.less +291 -291
  109. package/src/android-bootstrap/less/thumbnails.less +36 -36
  110. package/src/android-bootstrap/less/tooltip.less +102 -102
  111. package/src/android-bootstrap/less/type.less +303 -303
  112. package/src/android-bootstrap/less/utilities.less +55 -55
  113. package/src/android-bootstrap/less/variables.less +896 -896
  114. package/src/android-bootstrap/less/wells.less +29 -29
  115. package/src/bootstrap/fonts/glyphicons-halflings-regular.svg +287 -287
  116. package/src/bootstrap/less/.csscomb.json +304 -304
  117. package/src/bootstrap/less/.csslintrc +19 -19
  118. package/src/bootstrap/less/alerts.less +73 -73
  119. package/src/bootstrap/less/badges.less +66 -66
  120. package/src/bootstrap/less/bootstrap.less +56 -56
  121. package/src/bootstrap/less/breadcrumbs.less +26 -26
  122. package/src/bootstrap/less/button-groups.less +247 -247
  123. package/src/bootstrap/less/buttons.less +172 -172
  124. package/src/bootstrap/less/carousel.less +269 -269
  125. package/src/bootstrap/less/close.less +34 -34
  126. package/src/bootstrap/less/code.less +69 -69
  127. package/src/bootstrap/less/component-animations.less +33 -33
  128. package/src/bootstrap/less/dropdowns.less +216 -216
  129. package/src/bootstrap/less/forms.less +626 -626
  130. package/src/bootstrap/less/glyphicons.less +305 -305
  131. package/src/bootstrap/less/grid.less +84 -84
  132. package/src/bootstrap/less/input-groups.less +167 -167
  133. package/src/bootstrap/less/jumbotron.less +52 -52
  134. package/src/bootstrap/less/labels.less +64 -64
  135. package/src/bootstrap/less/list-group.less +141 -141
  136. package/src/bootstrap/less/media.less +66 -66
  137. package/src/bootstrap/less/mixins/alerts.less +14 -14
  138. package/src/bootstrap/less/mixins/background-variant.less +9 -9
  139. package/src/bootstrap/less/mixins/border-radius.less +18 -18
  140. package/src/bootstrap/less/mixins/buttons.less +69 -69
  141. package/src/bootstrap/less/mixins/center-block.less +7 -7
  142. package/src/bootstrap/less/mixins/clearfix.less +22 -22
  143. package/src/bootstrap/less/mixins/forms.less +90 -90
  144. package/src/bootstrap/less/mixins/gradients.less +59 -59
  145. package/src/bootstrap/less/mixins/grid-framework.less +92 -92
  146. package/src/bootstrap/less/mixins/grid.less +122 -122
  147. package/src/bootstrap/less/mixins/hide-text.less +21 -21
  148. package/src/bootstrap/less/mixins/image.less +33 -33
  149. package/src/bootstrap/less/mixins/labels.less +12 -12
  150. package/src/bootstrap/less/mixins/list-group.less +30 -30
  151. package/src/bootstrap/less/mixins/nav-divider.less +10 -10
  152. package/src/bootstrap/less/mixins/nav-vertical-align.less +9 -9
  153. package/src/bootstrap/less/mixins/opacity.less +8 -8
  154. package/src/bootstrap/less/mixins/pagination.less +24 -24
  155. package/src/bootstrap/less/mixins/panels.less +24 -24
  156. package/src/bootstrap/less/mixins/progress-bar.less +10 -10
  157. package/src/bootstrap/less/mixins/reset-filter.less +8 -8
  158. package/src/bootstrap/less/mixins/reset-text.less +18 -18
  159. package/src/bootstrap/less/mixins/resize.less +6 -6
  160. package/src/bootstrap/less/mixins/responsive-visibility.less +15 -15
  161. package/src/bootstrap/less/mixins/size.less +10 -10
  162. package/src/bootstrap/less/mixins/tab-focus.less +9 -9
  163. package/src/bootstrap/less/mixins/table-row.less +44 -44
  164. package/src/bootstrap/less/mixins/text-emphasis.less +9 -9
  165. package/src/bootstrap/less/mixins/text-overflow.less +8 -8
  166. package/src/bootstrap/less/mixins/vendor-prefixes.less +227 -227
  167. package/src/bootstrap/less/mixins.less +40 -40
  168. package/src/bootstrap/less/modals.less +151 -151
  169. package/src/bootstrap/less/navbar.less +660 -660
  170. package/src/bootstrap/less/navs.less +286 -286
  171. package/src/bootstrap/less/normalize.less +424 -424
  172. package/src/bootstrap/less/pager.less +76 -76
  173. package/src/bootstrap/less/pagination.less +89 -89
  174. package/src/bootstrap/less/panels.less +275 -275
  175. package/src/bootstrap/less/popovers.less +131 -131
  176. package/src/bootstrap/less/print.less +101 -101
  177. package/src/bootstrap/less/progress-bars.less +87 -87
  178. package/src/bootstrap/less/responsive-embed.less +35 -35
  179. package/src/bootstrap/less/responsive-utilities.less +194 -194
  180. package/src/bootstrap/less/scaffolding.less +161 -161
  181. package/src/bootstrap/less/tables.less +262 -262
  182. package/src/bootstrap/less/theme.less +291 -291
  183. package/src/bootstrap/less/thumbnails.less +36 -36
  184. package/src/bootstrap/less/tooltip.less +102 -102
  185. package/src/bootstrap/less/type.less +303 -303
  186. package/src/bootstrap/less/utilities.less +55 -55
  187. package/src/bootstrap/less/variables.less +895 -895
  188. package/src/bootstrap/less/wells.less +29 -29
  189. package/src/components/AloneLoadParams.vue +26 -26
  190. package/src/components/AlreadyService.vue +193 -193
  191. package/src/components/AttendManage.vue +397 -397
  192. package/src/components/LoadAppdata.vue +38 -38
  193. package/src/components/LoginApp.vue +615 -560
  194. package/src/components/LoginAppNew.vue +587 -587
  195. package/src/components/ModifyPassWord.vue +140 -131
  196. package/src/components/NavBottom.vue +117 -117
  197. package/src/components/NavBottomV.vue +141 -141
  198. package/src/components/NavBottomVVV.vue +185 -185
  199. package/src/components/OnlineManage.vue +268 -198
  200. package/src/components/PhoneChangemeterInfo.vue +116 -116
  201. package/src/components/PhoneInfoTable.vue +39 -39
  202. package/src/components/PhoneRepairInfo.vue +146 -146
  203. package/src/components/PhoneSellInfo.vue +123 -123
  204. package/src/components/PhoneSellInfoLite.vue +112 -112
  205. package/src/components/PhoneUser.vue +202 -202
  206. package/src/components/PhoneUserDetil.vue +70 -70
  207. package/src/components/PhoneUserFind.vue +138 -138
  208. package/src/components/RightTree.vue +214 -214
  209. package/src/components/SystemSetUp.vue +298 -298
  210. package/src/components/TabBarPhone.vue +81 -81
  211. package/src/components/Test.vue +14 -14
  212. package/src/components/ToolsPage.vue +165 -165
  213. package/src/components/UploadManage.vue +194 -194
  214. package/src/components/gaomi/NavBottomV.vue +223 -223
  215. package/src/components/gaomi/NavBottomVVVV.vue +210 -210
  216. package/src/components/gaomi/Scroller.vue +63 -63
  217. package/src/components/gaomi/SystemSetUp.vue +186 -186
  218. package/src/components/gaomi/ToolsPage.vue +168 -168
  219. package/src/components/idea/feedBack.vue +150 -150
  220. package/src/components/idea/feedbackAdd.vue +366 -366
  221. package/src/components/iot/InstructMessage.vue +313 -313
  222. package/src/components/iot/IotBaseInfo.vue +97 -97
  223. package/src/components/iot/IotMeterInfo.vue +77 -77
  224. package/src/components/iot/iotMonitoringMain.vue +501 -501
  225. package/src/components/online/ApplyOnline.vue +581 -581
  226. package/src/components/online/BJZhongRan/ApplyOnline.vue +600 -600
  227. package/src/components/screen/ChargeContentPage.vue +656 -656
  228. package/src/components/screen/ContentPage.vue +611 -611
  229. package/src/components/screen/GongdanContentPage.vue +149 -149
  230. package/src/components/screen/ListCountItem.vue +93 -93
  231. package/src/components/screen/ModuleTitle.vue +48 -48
  232. package/src/components/screen/SafeOrderContentPage.vue +440 -440
  233. package/src/components/screen/SecurityCheckItem.vue +50 -50
  234. package/src/components/screen/TotalItem.vue +76 -76
  235. package/src/components/screen/TotalUserNumber.vue +77 -77
  236. package/src/components/screen/WorkOrderItem.vue +51 -51
  237. package/src/components/screen/WorkOrderRightDownItem.vue +103 -103
  238. package/src/components/screen/WorkOrderRightItem.vue +115 -115
  239. package/src/components/userinfo/paymentQuery.vue +189 -189
  240. package/src/components/userinfo/queryFile.vue +190 -190
  241. package/src/components/wasm.vue +18 -18
  242. package/src/expandcssAndroid.less +521 -521
  243. package/src/index.js +9 -9
  244. package/src/main.js +38 -38
  245. package/src/plugins/GetStringData.js +18 -18
  246. package/src/plugins/LoadParams.js +24 -24
  247. package/src/plugins/const.js +404 -404
  248. package/src/plugins/vue-py.js +37 -37
  249. package/src/services/ConfigService.js +24 -24
  250. package/src/stores/AppData.js +63 -63
  251. package/src/systemphone-gaomi.js +105 -105
  252. package/src/systemphone.js +58 -58
  253. package/src/systemphonegrid.js +186 -186
  254. package/src/util/LdapHelper.js +75 -75
  255. package/static/app.json +4 -4
  256. package/static/const.js +404 -404
  257. package/static/globals.txt +74 -74
  258. package/static/layui/font/iconfont.svg +554 -554
  259. package/static/vue-py.js +37 -37
  260. package/static/wasm_exec.js +465 -465
  261. package/test/unit/.eslintrc +5 -5
  262. package/test/unit/TestUtil.js +35 -35
  263. package/test/unit/context.html +20 -20
  264. package/test/unit/index.js +13 -13
  265. package/test/unit/init.js +13 -13
  266. package/test/unit/karma.conf.js +50 -50
  267. package/test/unit/specs/App.spec.js +17 -17
  268. package/test/unit/specs/Test.spec.js +28 -28
  269. package/test/unit/specs/components/LoginApp.spec.js +21 -21
  270. package/test/unit/specs/sevices/ConfigService.spec.js +23 -23
  271. package/test/unit/specs/sevices/GetDBTest.spec.js +28 -28
@@ -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
+ }