system-clients 3.2.3-aodeToV4 → 3.2.4-aodeToV4

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 (141) hide show
  1. package/.eslintrc.js +16 -16
  2. package/.gradle/buildOutputCleanup/cache.properties +2 -2
  3. package/SystemClient.iml +11 -11
  4. package/build/webpack.base.conf.js +78 -78
  5. package/build.gradle +6 -6
  6. package/gradle/wrapper/gradle-wrapper.properties +5 -5
  7. package/gradlew +185 -185
  8. package/gradlew.bat +89 -89
  9. package/index.html +21 -21
  10. package/package.json +102 -102
  11. package/src/App.vue +24 -24
  12. package/src/LodopFuncs.js +123 -123
  13. package/src/components/Main.vue +515 -515
  14. package/src/components/Util.js +343 -343
  15. package/src/components/equipment/EquipmentManage.vue +65 -65
  16. package/src/components/equipment/PcAdd.vue +105 -105
  17. package/src/components/equipment/PcList.vue +120 -120
  18. package/src/components/equipment/PcManage.vue +60 -60
  19. package/src/components/equipment/PhoneAdd.vue +94 -94
  20. package/src/components/equipment/PhoneList.vue +102 -102
  21. package/src/components/equipment/PhoneManage.vue +60 -60
  22. package/src/components/equipment/PosAdd.vue +156 -156
  23. package/src/components/equipment/PosList.vue +164 -164
  24. package/src/components/equipment/PosManage.vue +68 -68
  25. package/src/components/materialManage/materialData.vue +44 -44
  26. package/src/components/materialManage/materialList.vue +255 -255
  27. package/src/components/parammanage/ParamManage.vue +42 -42
  28. package/src/components/parammanage/ParamPage.vue +314 -314
  29. package/src/components/parammanage/ParamPages.vue +222 -222
  30. package/src/components/parammanage/SinglePage.vue +235 -235
  31. package/src/components/parammanage/SinglePages.vue +167 -167
  32. package/src/components/server/AddChangeMsg.vue +66 -66
  33. package/src/components/server/ChangeDeclare.vue +45 -45
  34. package/src/components/server/LeftTree.vue +111 -111
  35. package/src/components/server/LoadData.vue +36 -36
  36. package/src/components/server/Login.vue +726 -726
  37. package/src/components/server/Menu.vue +188 -188
  38. package/src/components/server/ModifyPw.vue +112 -112
  39. package/src/components/server/NewResSelectGroup.vue +211 -211
  40. package/src/components/server/ResSelect.vue +153 -153
  41. package/src/components/server/ResSelectGroup.vue +159 -159
  42. package/src/components/server/RightTree.vue +343 -343
  43. package/src/components/server/RoleSelector.vue +90 -90
  44. package/src/components/server/TestResSelect.vue +58 -58
  45. package/src/components/server/TestResSelectGroup.vue +388 -388
  46. package/src/plugins/EncryptUtil.js +53 -53
  47. package/src/plugins/GetLoginInfoService.js +499 -499
  48. package/src/plugins/HeatGetLoginInfoService.js +491 -491
  49. package/src/plugins/validation.js +7 -7
  50. package/src/project/State.js +17 -17
  51. package/src/stores/AppData.js +38 -38
  52. package/src/stores/HeatAppData.js +38 -38
  53. package/src/styles/fonts/glyphicons-halflings-regular.svg +287 -287
  54. package/src/styles/less/.csscomb.json +304 -304
  55. package/src/styles/less/.csslintrc +19 -19
  56. package/src/styles/less/alerts.less +73 -73
  57. package/src/styles/less/aofeng/animate.min.css +10 -10
  58. package/src/styles/less/aofeng/expandcss.less +569 -569
  59. package/src/styles/less/aofeng/standard.less +2121 -2121
  60. package/src/styles/less/aofeng/themeOne/BinaryTemplate.less +686 -686
  61. package/src/styles/less/aofeng/themeOne/loginStyle.less +1586 -1586
  62. package/src/styles/less/aofeng/themeOne/systemStyle.less +2650 -2650
  63. package/src/styles/less/aofeng/themeOne.less +17 -17
  64. package/src/styles/less/aofeng/themeTwo/newStyle1.less +415 -415
  65. package/src/styles/less/aofeng/themeTwo.less +3 -3
  66. package/src/styles/less/badges.less +66 -66
  67. package/src/styles/less/bootstrap.less +66 -66
  68. package/src/styles/less/breadcrumbs.less +26 -26
  69. package/src/styles/less/button-groups.less +247 -247
  70. package/src/styles/less/buttons.less +172 -172
  71. package/src/styles/less/carousel.less +269 -269
  72. package/src/styles/less/close.less +34 -34
  73. package/src/styles/less/code.less +69 -69
  74. package/src/styles/less/component-animations.less +33 -33
  75. package/src/styles/less/dropdowns.less +216 -216
  76. package/src/styles/less/fonts-list.less +25 -25
  77. package/src/styles/less/forms.less +626 -626
  78. package/src/styles/less/glyphicons.less +305 -305
  79. package/src/styles/less/grid.less +84 -84
  80. package/src/styles/less/input-groups.less +167 -167
  81. package/src/styles/less/jumbotron.less +52 -52
  82. package/src/styles/less/labels.less +64 -64
  83. package/src/styles/less/list-group.less +141 -141
  84. package/src/styles/less/manageStyle/manageChile.less +180 -180
  85. package/src/styles/less/manageStyle/manageStyle.less +1102 -1102
  86. package/src/styles/less/manageStyle/safeStyle.less +498 -498
  87. package/src/styles/less/media.less +66 -66
  88. package/src/styles/less/mixins/alerts.less +14 -14
  89. package/src/styles/less/mixins/background-variant.less +9 -9
  90. package/src/styles/less/mixins/border-radius.less +18 -18
  91. package/src/styles/less/mixins/buttons.less +69 -69
  92. package/src/styles/less/mixins/center-block.less +7 -7
  93. package/src/styles/less/mixins/clearfix.less +22 -22
  94. package/src/styles/less/mixins/forms.less +90 -90
  95. package/src/styles/less/mixins/gradients.less +59 -59
  96. package/src/styles/less/mixins/grid-framework.less +92 -92
  97. package/src/styles/less/mixins/grid.less +122 -122
  98. package/src/styles/less/mixins/hide-text.less +21 -21
  99. package/src/styles/less/mixins/image.less +33 -33
  100. package/src/styles/less/mixins/labels.less +12 -12
  101. package/src/styles/less/mixins/list-group.less +30 -30
  102. package/src/styles/less/mixins/nav-divider.less +10 -10
  103. package/src/styles/less/mixins/nav-vertical-align.less +9 -9
  104. package/src/styles/less/mixins/opacity.less +8 -8
  105. package/src/styles/less/mixins/pagination.less +24 -24
  106. package/src/styles/less/mixins/panels.less +24 -24
  107. package/src/styles/less/mixins/progress-bar.less +10 -10
  108. package/src/styles/less/mixins/reset-filter.less +8 -8
  109. package/src/styles/less/mixins/reset-text.less +18 -18
  110. package/src/styles/less/mixins/resize.less +6 -6
  111. package/src/styles/less/mixins/responsive-visibility.less +15 -15
  112. package/src/styles/less/mixins/size.less +10 -10
  113. package/src/styles/less/mixins/tab-focus.less +9 -9
  114. package/src/styles/less/mixins/table-row.less +44 -44
  115. package/src/styles/less/mixins/text-emphasis.less +9 -9
  116. package/src/styles/less/mixins/text-overflow.less +8 -8
  117. package/src/styles/less/mixins/vendor-prefixes.less +227 -227
  118. package/src/styles/less/mixins.less +40 -40
  119. package/src/styles/less/modals.less +151 -151
  120. package/src/styles/less/navbar.less +660 -660
  121. package/src/styles/less/navs.less +285 -285
  122. package/src/styles/less/normalize.less +424 -424
  123. package/src/styles/less/pager.less +76 -76
  124. package/src/styles/less/pagination.less +89 -89
  125. package/src/styles/less/panels.less +275 -275
  126. package/src/styles/less/popovers.less +131 -131
  127. package/src/styles/less/print.less +101 -101
  128. package/src/styles/less/progress-bars.less +87 -87
  129. package/src/styles/less/responsive-embed.less +35 -35
  130. package/src/styles/less/responsive-utilities.less +194 -194
  131. package/src/styles/less/scaffolding.less +161 -161
  132. package/src/styles/less/stand.less +207 -207
  133. package/src/styles/less/tables.less +262 -262
  134. package/src/styles/less/theme.less +291 -291
  135. package/src/styles/less/thumbnails.less +36 -36
  136. package/src/styles/less/tooltip.less +102 -102
  137. package/src/styles/less/type.less +303 -303
  138. package/src/styles/less/utilities.less +55 -55
  139. package/src/styles/less/variables.less +896 -896
  140. package/src/styles/less/wells.less +29 -29
  141. package/src/system.js +85 -85
@@ -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
+ }