survey-core 1.9.138 → 1.9.139

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 (257) hide show
  1. package/defaultV2.css +352 -15
  2. package/defaultV2.css.map +1 -1
  3. package/defaultV2.fontless.css +352 -15
  4. package/defaultV2.fontless.css.map +1 -1
  5. package/defaultV2.fontless.min.css +2 -2
  6. package/defaultV2.min.css +2 -2
  7. package/i18n/arabic.js +1 -1
  8. package/i18n/arabic.min.js +1 -1
  9. package/i18n/basque.js +1 -1
  10. package/i18n/basque.min.js +1 -1
  11. package/i18n/bulgarian.js +1 -1
  12. package/i18n/bulgarian.min.js +1 -1
  13. package/i18n/catalan.js +1 -1
  14. package/i18n/catalan.min.js +1 -1
  15. package/i18n/croatian.js +1 -1
  16. package/i18n/croatian.min.js +1 -1
  17. package/i18n/czech.js +1 -1
  18. package/i18n/czech.min.js +1 -1
  19. package/i18n/danish.js +1 -1
  20. package/i18n/danish.min.js +1 -1
  21. package/i18n/dutch.js +1 -1
  22. package/i18n/dutch.min.js +1 -1
  23. package/i18n/english.js +4 -3
  24. package/i18n/english.js.map +1 -1
  25. package/i18n/english.min.js +2 -2
  26. package/i18n/estonian.js +1 -1
  27. package/i18n/estonian.min.js +1 -1
  28. package/i18n/finnish.js +1 -1
  29. package/i18n/finnish.min.js +1 -1
  30. package/i18n/french.js +1 -1
  31. package/i18n/french.min.js +1 -1
  32. package/i18n/georgian.js +1 -1
  33. package/i18n/georgian.min.js +1 -1
  34. package/i18n/german.js +1 -1
  35. package/i18n/german.min.js +1 -1
  36. package/i18n/greek.js +1 -1
  37. package/i18n/greek.min.js +1 -1
  38. package/i18n/hebrew.js +1 -1
  39. package/i18n/hebrew.min.js +1 -1
  40. package/i18n/hindi.js +1 -1
  41. package/i18n/hindi.min.js +1 -1
  42. package/i18n/hungarian.js +1 -1
  43. package/i18n/hungarian.min.js +1 -1
  44. package/i18n/icelandic.js +1 -1
  45. package/i18n/icelandic.min.js +1 -1
  46. package/i18n/index.js +1 -1
  47. package/i18n/index.min.js +1 -1
  48. package/i18n/indonesian.js +1 -1
  49. package/i18n/indonesian.min.js +1 -1
  50. package/i18n/italian.js +1 -1
  51. package/i18n/italian.min.js +1 -1
  52. package/i18n/japanese.js +1 -1
  53. package/i18n/japanese.min.js +1 -1
  54. package/i18n/kazakh.js +1 -1
  55. package/i18n/kazakh.min.js +1 -1
  56. package/i18n/korean.js +1 -1
  57. package/i18n/korean.min.js +1 -1
  58. package/i18n/latvian.js +1 -1
  59. package/i18n/latvian.min.js +1 -1
  60. package/i18n/lithuanian.js +1 -1
  61. package/i18n/lithuanian.min.js +1 -1
  62. package/i18n/macedonian.js +1 -1
  63. package/i18n/macedonian.min.js +1 -1
  64. package/i18n/malay.js +1 -1
  65. package/i18n/malay.min.js +1 -1
  66. package/i18n/nl-BE.js +1 -1
  67. package/i18n/nl-BE.min.js +1 -1
  68. package/i18n/norwegian.js +1 -1
  69. package/i18n/norwegian.min.js +1 -1
  70. package/i18n/persian.js +1 -1
  71. package/i18n/persian.min.js +1 -1
  72. package/i18n/polish.js +1 -1
  73. package/i18n/polish.min.js +1 -1
  74. package/i18n/portuguese-br.js +1 -1
  75. package/i18n/portuguese-br.min.js +1 -1
  76. package/i18n/portuguese.js +1 -1
  77. package/i18n/portuguese.min.js +1 -1
  78. package/i18n/romanian.js +1 -1
  79. package/i18n/romanian.min.js +1 -1
  80. package/i18n/russian.js +1 -1
  81. package/i18n/russian.min.js +1 -1
  82. package/i18n/serbian.js +1 -1
  83. package/i18n/serbian.min.js +1 -1
  84. package/i18n/simplified-chinese.js +1 -1
  85. package/i18n/simplified-chinese.min.js +1 -1
  86. package/i18n/slovak.js +1 -1
  87. package/i18n/slovak.min.js +1 -1
  88. package/i18n/spanish.js +1 -1
  89. package/i18n/spanish.min.js +1 -1
  90. package/i18n/swahili.js +1 -1
  91. package/i18n/swahili.min.js +1 -1
  92. package/i18n/swedish.js +1 -1
  93. package/i18n/swedish.min.js +1 -1
  94. package/i18n/tajik.js +1 -1
  95. package/i18n/tajik.min.js +1 -1
  96. package/i18n/telugu.js +1 -1
  97. package/i18n/telugu.min.js +1 -1
  98. package/i18n/thai.js +1 -1
  99. package/i18n/thai.min.js +1 -1
  100. package/i18n/traditional-chinese.js +1 -1
  101. package/i18n/traditional-chinese.min.js +1 -1
  102. package/i18n/turkish.js +1 -1
  103. package/i18n/turkish.min.js +1 -1
  104. package/i18n/ukrainian.js +1 -1
  105. package/i18n/ukrainian.min.js +1 -1
  106. package/i18n/urdu.js +1 -1
  107. package/i18n/urdu.min.js +1 -1
  108. package/i18n/vietnamese.js +1 -1
  109. package/i18n/vietnamese.min.js +1 -1
  110. package/i18n/welsh.js +1 -1
  111. package/i18n/welsh.min.js +1 -1
  112. package/modern.css +19 -3
  113. package/modern.css.map +1 -1
  114. package/modern.fontless.css +19 -3
  115. package/modern.fontless.css.map +1 -1
  116. package/modern.fontless.min.css +2 -2
  117. package/modern.min.css +2 -2
  118. package/package.json +1 -1
  119. package/plugins/bootstrap-integration.js +1 -1
  120. package/plugins/bootstrap-integration.min.js +1 -1
  121. package/plugins/bootstrap-material-integration.js +1 -1
  122. package/plugins/bootstrap-material-integration.min.js +1 -1
  123. package/survey.core.js +549 -89
  124. package/survey.core.js.map +1 -1
  125. package/survey.core.min.js +3 -3
  126. package/survey.css +1 -1
  127. package/survey.i18n.js +1 -1
  128. package/survey.i18n.min.js +1 -1
  129. package/survey.min.css +1 -1
  130. package/themes/borderless-dark-panelless.js +1 -1
  131. package/themes/borderless-dark-panelless.min.js +1 -1
  132. package/themes/borderless-dark.js +1 -1
  133. package/themes/borderless-dark.min.js +1 -1
  134. package/themes/borderless-light-panelless..js +1 -1
  135. package/themes/borderless-light-panelless..min.js +1 -1
  136. package/themes/borderless-light.js +1 -1
  137. package/themes/borderless-light.min.js +1 -1
  138. package/themes/contrast-dark-panelless.js +1 -1
  139. package/themes/contrast-dark-panelless.min.js +1 -1
  140. package/themes/contrast-dark.js +1 -1
  141. package/themes/contrast-dark.min.js +1 -1
  142. package/themes/contrast-light-panelless.js +1 -1
  143. package/themes/contrast-light-panelless.min.js +1 -1
  144. package/themes/contrast-light.js +1 -1
  145. package/themes/contrast-light.min.js +1 -1
  146. package/themes/default-dark-panelless.js +1 -1
  147. package/themes/default-dark-panelless.min.js +1 -1
  148. package/themes/default-dark.js +1 -1
  149. package/themes/default-dark.min.js +1 -1
  150. package/themes/default-light-panelless.js +1 -1
  151. package/themes/default-light-panelless.min.js +1 -1
  152. package/themes/default-light.js +1 -1
  153. package/themes/default-light.min.js +1 -1
  154. package/themes/doubleborder-dark-panelless.js +1 -1
  155. package/themes/doubleborder-dark-panelless.min.js +1 -1
  156. package/themes/doubleborder-dark.js +1 -1
  157. package/themes/doubleborder-dark.min.js +1 -1
  158. package/themes/doubleborder-light-panelles.js +1 -1
  159. package/themes/doubleborder-light-panelles.min.js +1 -1
  160. package/themes/doubleborder-light.js +1 -1
  161. package/themes/doubleborder-light.min.js +1 -1
  162. package/themes/flat-dark-panelless.js +1 -1
  163. package/themes/flat-dark-panelless.min.js +1 -1
  164. package/themes/flat-dark.js +1 -1
  165. package/themes/flat-dark.min.js +1 -1
  166. package/themes/flat-light-panelless.js +1 -1
  167. package/themes/flat-light-panelless.min.js +1 -1
  168. package/themes/flat-light.js +1 -1
  169. package/themes/flat-light.min.js +1 -1
  170. package/themes/index.js +1 -1
  171. package/themes/index.min.js +1 -1
  172. package/themes/layered-dark-panelless.js +1 -1
  173. package/themes/layered-dark-panelless.min.js +1 -1
  174. package/themes/layered-dark.js +1 -1
  175. package/themes/layered-dark.min.js +1 -1
  176. package/themes/layered-light-panelless.js +1 -1
  177. package/themes/layered-light-panelless.min.js +1 -1
  178. package/themes/layered-light.js +1 -1
  179. package/themes/layered-light.min.js +1 -1
  180. package/themes/plain-dark-panelless.js +1 -1
  181. package/themes/plain-dark-panelless.min.js +1 -1
  182. package/themes/plain-dark.js +1 -1
  183. package/themes/plain-dark.min.js +1 -1
  184. package/themes/plain-light-panelless.js +1 -1
  185. package/themes/plain-light-panelless.min.js +1 -1
  186. package/themes/plain-light.js +1 -1
  187. package/themes/plain-light.min.js +1 -1
  188. package/themes/sharp-dark-panelless.js +1 -1
  189. package/themes/sharp-dark-panelless.min.js +1 -1
  190. package/themes/sharp-dark.js +1 -1
  191. package/themes/sharp-dark.min.js +1 -1
  192. package/themes/sharp-light-panelless.js +1 -1
  193. package/themes/sharp-light-panelless.min.js +1 -1
  194. package/themes/sharp-light.js +1 -1
  195. package/themes/sharp-light.min.js +1 -1
  196. package/themes/solid-dark-panelless.js +1 -1
  197. package/themes/solid-dark-panelless.min.js +1 -1
  198. package/themes/solid-dark.js +1 -1
  199. package/themes/solid-dark.min.js +1 -1
  200. package/themes/solid-light-panelless.js +1 -1
  201. package/themes/solid-light-panelless.min.js +1 -1
  202. package/themes/solid-light.js +1 -1
  203. package/themes/solid-light.min.js +1 -1
  204. package/themes/three-dimensional-dark-panelless.js +1 -1
  205. package/themes/three-dimensional-dark-panelless.min.js +1 -1
  206. package/themes/three-dimensional-dark.js +1 -1
  207. package/themes/three-dimensional-dark.min.js +1 -1
  208. package/themes/three-dimensional-light-panelless.js +1 -1
  209. package/themes/three-dimensional-light-panelless.min.js +1 -1
  210. package/themes/three-dimensional-light.js +1 -1
  211. package/themes/three-dimensional-light.min.js +1 -1
  212. package/ts3.4/typings/actions/action.d.ts +6 -1
  213. package/ts3.4/typings/base-interfaces.d.ts +1 -1
  214. package/ts3.4/typings/defaultCss/cssmodern.d.ts +1 -1
  215. package/ts3.4/typings/defaultCss/cssstandard.d.ts +1 -1
  216. package/ts3.4/typings/defaultCss/defaultV2Css.d.ts +52 -1
  217. package/ts3.4/typings/knockout/kobase.d.ts +8 -0
  218. package/ts3.4/typings/knockout/kopage.d.ts +37 -0
  219. package/ts3.4/typings/localization/english.d.ts +1 -0
  220. package/ts3.4/typings/mask/input_element_adapter.d.ts +1 -1
  221. package/ts3.4/typings/mask/mask_datetime.d.ts +16 -1
  222. package/ts3.4/typings/mask/mask_pattern.d.ts +9 -1
  223. package/ts3.4/typings/panel.d.ts +1 -1
  224. package/ts3.4/typings/popup.d.ts +1 -0
  225. package/ts3.4/typings/question.d.ts +1 -0
  226. package/ts3.4/typings/question_boolean.d.ts +8 -0
  227. package/ts3.4/typings/question_custom.d.ts +1 -0
  228. package/ts3.4/typings/question_matrix.d.ts +1 -0
  229. package/ts3.4/typings/question_paneldynamic.d.ts +1 -0
  230. package/ts3.4/typings/question_ranking.d.ts +1 -0
  231. package/ts3.4/typings/question_signaturepad.d.ts +9 -2
  232. package/ts3.4/typings/survey-element.d.ts +4 -0
  233. package/ts3.4/typings/survey.d.ts +1 -1
  234. package/ts3.4/typings/surveyStrings.d.ts +1 -0
  235. package/typings/actions/action.d.ts +7 -1
  236. package/typings/base-interfaces.d.ts +1 -1
  237. package/typings/defaultCss/cssmodern.d.ts +1 -1
  238. package/typings/defaultCss/cssstandard.d.ts +1 -1
  239. package/typings/defaultCss/defaultV2Css.d.ts +52 -1
  240. package/typings/knockout/kobase.d.ts +8 -0
  241. package/typings/knockout/kopage.d.ts +37 -0
  242. package/typings/localization/english.d.ts +1 -0
  243. package/typings/mask/input_element_adapter.d.ts +1 -1
  244. package/typings/mask/mask_datetime.d.ts +16 -1
  245. package/typings/mask/mask_pattern.d.ts +9 -1
  246. package/typings/panel.d.ts +1 -1
  247. package/typings/popup.d.ts +1 -0
  248. package/typings/question.d.ts +1 -0
  249. package/typings/question_boolean.d.ts +8 -0
  250. package/typings/question_custom.d.ts +1 -0
  251. package/typings/question_matrix.d.ts +1 -0
  252. package/typings/question_paneldynamic.d.ts +1 -0
  253. package/typings/question_ranking.d.ts +1 -0
  254. package/typings/question_signaturepad.d.ts +9 -2
  255. package/typings/survey-element.d.ts +4 -0
  256. package/typings/survey.d.ts +1 -1
  257. package/typings/surveyStrings.d.ts +1 -0
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * surveyjs - Survey JavaScript library v1.9.138
2
+ * surveyjs - Survey JavaScript library v1.9.139
3
3
  * Copyright (c) 2015-2024 Devsoft Baltic OÜ - http://surveyjs.io/
4
4
  * License: MIT (http://www.opensource.org/licenses/mit-license.php)
5
5
  */
@@ -1149,10 +1149,16 @@ sv-brand-info, .sv-brand-info {
1149
1149
  height: calc(4 * (var(--sjs-base-unit, var(--base-unit, 8px))));
1150
1150
  }
1151
1151
 
1152
- .sv-ranking-item--disabled.sv-ranking-item--disabled {
1152
+ .sv-ranking-item--disabled.sv-ranking-item--disabled,
1153
+ .sv-ranking-item--readonly.sv-ranking-item--readonly,
1154
+ .sv-ranking-item--preview.sv-ranking-item--preview {
1153
1155
  cursor: initial;
1156
+ user-select: initial;
1157
+ -webkit-user-select: initial;
1154
1158
  }
1155
- .sv-ranking-item--disabled.sv-ranking-item--disabled .sv-ranking-item__icon-container.sv-ranking-item__icon-container .sv-ranking-item__icon.sv-ranking-item__icon {
1159
+ .sv-ranking-item--disabled.sv-ranking-item--disabled .sv-ranking-item__icon-container.sv-ranking-item__icon-container .sv-ranking-item__icon.sv-ranking-item__icon,
1160
+ .sv-ranking-item--readonly.sv-ranking-item--readonly .sv-ranking-item__icon-container.sv-ranking-item__icon-container .sv-ranking-item__icon.sv-ranking-item__icon,
1161
+ .sv-ranking-item--preview.sv-ranking-item--preview .sv-ranking-item__icon-container.sv-ranking-item__icon-container .sv-ranking-item__icon.sv-ranking-item__icon {
1156
1162
  visibility: hidden;
1157
1163
  }
1158
1164
 
@@ -1213,6 +1219,16 @@ sv-brand-info, .sv-brand-info {
1213
1219
  opacity: 0.25;
1214
1220
  }
1215
1221
 
1222
+ .sv-ranking-item--readonly .sv-ranking-item__index {
1223
+ background-color: var(--sjs-questionpanel-hovercolor, var(--sjs-general-backcolor-dark, rgb(248, 248, 248)));
1224
+ }
1225
+
1226
+ .sv-ranking-item--preview .sv-ranking-item__index {
1227
+ background-color: transparent;
1228
+ border: 1px solid var(--sjs-general-forecolor, var(--foreground, #161616));
1229
+ box-sizing: border-box;
1230
+ }
1231
+
1216
1232
  .sv-ranking-item__ghost.sv-ranking-item__ghost {
1217
1233
  display: none;
1218
1234
  background-color: var(--sjs-general-backcolor-dim, var(--background-dim, #f3f3f3));
@@ -2373,6 +2389,20 @@ textarea.sd-input:disabled:not(.sd-input--disabled) {
2373
2389
  user-select: none;
2374
2390
  }
2375
2391
 
2392
+ .sd-input--readonly {
2393
+ background-color: var(--sjs-questionpanel-hovercolor, var(--sjs-general-backcolor-dark, rgb(248, 248, 248)));
2394
+ }
2395
+
2396
+ .sd-input.sd-input--preview {
2397
+ background: none;
2398
+ box-shadow: none;
2399
+ transition: none;
2400
+ border-bottom: 1px solid var(--sjs-general-forecolor, var(--foreground, #161616));
2401
+ border-radius: 0;
2402
+ padding-left: 0;
2403
+ padding-right: 0;
2404
+ }
2405
+
2376
2406
  .sd-input::placeholder {
2377
2407
  color: var(--sjs-font-editorfont-placeholdercolor, var(--sjs-general-forecolor-light, var(--foreground-light, #909090)));
2378
2408
  -webkit-user-select: none;
@@ -2387,6 +2417,16 @@ textarea.sd-input:disabled:not(.sd-input--disabled) {
2387
2417
  opacity: 0.25;
2388
2418
  }
2389
2419
 
2420
+ .sd-input.sd-input--readonly {
2421
+ color: var(--sjs-general-forecolor, var(--foreground, #161616));
2422
+ box-shadow: none;
2423
+ transition: none;
2424
+ }
2425
+
2426
+ .sd-input.sd-input--readonly::placeholder {
2427
+ color: var(--sjs-general-forecolor-light, var(--foreground-light, #909090));
2428
+ }
2429
+
2390
2430
  .sd-root--readonly .sd-input--disabled,
2391
2431
  .sd-root--readonly .sd-input--disabled::placeholder {
2392
2432
  color: var(--sjs-general-forecolor, var(--foreground, #161616));
@@ -2600,6 +2640,15 @@ textarea.sd-input:disabled:not(.sd-input--disabled) {
2600
2640
  border: 1px dashed var(--sjs-border-default, var(--border, #d6d6d6));
2601
2641
  }
2602
2642
 
2643
+ .sd-question--readonly .sjs_sp_container,
2644
+ .sd-question--preview .sjs_sp_container {
2645
+ border: none;
2646
+ }
2647
+ .sd-question--readonly .sjs_sp_placeholder,
2648
+ .sd-question--preview .sjs_sp_placeholder {
2649
+ color: var(--sjs-general-forecolor, var(--foreground, #161616));
2650
+ }
2651
+
2603
2652
  .sjs_sp_controls.sd-signaturepad__controls {
2604
2653
  right: var(--sjs-base-unit, var(--base-unit, 8px));
2605
2654
  top: var(--sjs-base-unit, var(--base-unit, 8px));
@@ -2657,6 +2706,14 @@ textarea.sd-input:disabled:not(.sd-input--disabled) {
2657
2706
  fill: var(--sjs-primary-backcolor, var(--primary, #19b394));
2658
2707
  }
2659
2708
 
2709
+ .sd-checkbox--checked.sd-checkbox--readonly .sd-checkbox__svg use {
2710
+ fill: var(--sjs-general-forecolor, var(--foreground, #161616));
2711
+ }
2712
+
2713
+ .sd-checkbox--checked.sd-checkbox--preview .sd-checkbox__svg use {
2714
+ fill: var(--sjs-general-forecolor, var(--foreground, #161616));
2715
+ }
2716
+
2660
2717
  .sd-matrixdynamic__btn.sd-matrixdynamic__add-btn {
2661
2718
  position: sticky;
2662
2719
  left: calc(-3 * (var(--sjs-base-unit, var(--base-unit, 8px))));
@@ -2813,9 +2870,9 @@ textarea.sd-input:disabled:not(.sd-input--disabled) {
2813
2870
  }
2814
2871
  .sd-root-modern:not(.sd-root-modern--mobile) .sd-table--alternate-rows .sd-table__row:nth-of-type(odd) > td.sd-table__cell:not(.sd-table__cell--actions),
2815
2872
  .sd-root-modern:not(.sd-root-modern--mobile) .sd-table--alternate-rows .sd-table__row:nth-of-type(odd) td:first-of-type {
2816
- border-top-color: var(--sjs-general-backcolor-dim-light, var(--background-dim-light, #f9f9f9));
2817
- border-bottom-color: var(--sjs-general-backcolor-dim-light, var(--background-dim-light, #f9f9f9));
2818
- background-color: var(--sjs-general-backcolor-dim-light, var(--background-dim-light, #f9f9f9));
2873
+ border-top-color: var(--sjs-questionpanel-hovercolor, var(--sjs-general-backcolor-dark, rgb(248, 248, 248)));
2874
+ border-bottom-color: var(--sjs-questionpanel-hovercolor, var(--sjs-general-backcolor-dark, rgb(248, 248, 248)));
2875
+ background-color: var(--sjs-questionpanel-hovercolor, var(--sjs-general-backcolor-dark, rgb(248, 248, 248)));
2819
2876
  }
2820
2877
  .sd-root-modern:not(.sd-root-modern--mobile) .sd-table--alternate-rows .sd-table__row:nth-of-type(odd) > td.sd-table__cell:not(.sd-table__cell--actions).sd-matrix__text--checked,
2821
2878
  .sd-root-modern:not(.sd-root-modern--mobile) .sd-table--alternate-rows .sd-table__row:nth-of-type(odd) td:first-of-type.sd-matrix__text--checked {
@@ -2833,6 +2890,14 @@ textarea.sd-input:disabled:not(.sd-input--disabled) {
2833
2890
  .sd-root-modern:not(.sd-root-modern--mobile) .sd-table--alternate-rows .sd-table__row:nth-of-type(odd) td:first-of-type .sd-item:not(.sd-item--error).sd-item--checked .sd-item__decorator {
2834
2891
  background-color: var(--sjs-primary-backcolor, var(--primary, #19b394));
2835
2892
  }
2893
+ .sd-root-modern:not(.sd-root-modern--mobile) .sd-table--alternate-rows .sd-table__row:nth-of-type(odd) > td.sd-table__cell:not(.sd-table__cell--actions) .sd-item:not(.sd-item--error).sd-item--readonly.sd-item--checked .sd-item__decorator,
2894
+ .sd-root-modern:not(.sd-root-modern--mobile) .sd-table--alternate-rows .sd-table__row:nth-of-type(odd) td:first-of-type .sd-item:not(.sd-item--error).sd-item--readonly.sd-item--checked .sd-item__decorator {
2895
+ background-color: var(--sjs-general-backcolor, var(--background, #fff));
2896
+ }
2897
+ .sd-root-modern:not(.sd-root-modern--mobile) .sd-table--alternate-rows .sd-table__row:nth-of-type(odd) > td.sd-table__cell:not(.sd-table__cell--actions) .sd-item:not(.sd-item--error).sd-item--preview.sd-item--preview .sd-item__decorator,
2898
+ .sd-root-modern:not(.sd-root-modern--mobile) .sd-table--alternate-rows .sd-table__row:nth-of-type(odd) td:first-of-type .sd-item:not(.sd-item--error).sd-item--preview.sd-item--preview .sd-item__decorator {
2899
+ background-color: transparent;
2900
+ }
2836
2901
  .sd-root-modern:not(.sd-root-modern--mobile) .sd-table--alternate-rows .sd-table__row:nth-of-type(odd) > td.sd-table__cell:not(.sd-table__cell--actions) .sd-item:not(.sd-item--error).sd-radio--checked .sd-radio__control:focus + .sd-radio__decorator:after,
2837
2902
  .sd-root-modern:not(.sd-root-modern--mobile) .sd-table--alternate-rows .sd-table__row:nth-of-type(odd) td:first-of-type .sd-item:not(.sd-item--error).sd-radio--checked .sd-radio__control:focus + .sd-radio__decorator:after {
2838
2903
  background-color: var(--sjs-primary-forecolor, var(--primary-foreground, #fff));
@@ -3073,6 +3138,24 @@ textarea.sd-input:disabled:not(.sd-input--disabled) {
3073
3138
  flex-basis: 100%;
3074
3139
  }
3075
3140
 
3141
+ .sd-element--with-frame.sd-element--compact .sd-table {
3142
+ background-color: var(--sjs-general-backcolor-dim, var(--background-dim, #f3f3f3));
3143
+ }
3144
+ .sd-element--with-frame.sd-element--compact .sd-table-wrapper:before, .sd-element--with-frame.sd-element--compact .sd-table-wrapper:after {
3145
+ background-color: var(--sjs-general-backcolor-dim, var(--background-dim, #f3f3f3));
3146
+ }
3147
+ .sd-element--with-frame.sd-element--compact .sd-table__cell--actions:not(.sd-table__cell--vertical):last-child .sd-action-bar {
3148
+ background-color: var(--sjs-general-backcolor-dim, var(--background-dim, #f3f3f3));
3149
+ }
3150
+ .sd-element--with-frame.sd-element--compact .sd-table__cell--actions:not(.sd-table__cell--vertical),
3151
+ .sd-element--with-frame.sd-element--compact .sd-table__cell--empty,
3152
+ .sd-element--with-frame.sd-element--compact .sd-table__cell--row-text,
3153
+ .sd-element--with-frame.sd-element--compact .sd-table__cell--footer-total,
3154
+ .sd-element--with-frame.sd-element--compact .sd-matrix__cell:first-of-type,
3155
+ .sd-element--with-frame.sd-element--compact .sd-matrix tr > td:first-of-type {
3156
+ background-color: var(--sjs-general-backcolor-dim, var(--background-dim, #f3f3f3));
3157
+ }
3158
+
3076
3159
  .sd-question--table > .sd-question__header,
3077
3160
  .sd-question--table .sd-question__description--under-input .sv-string-viewer {
3078
3161
  position: sticky;
@@ -3448,6 +3531,18 @@ textarea.sd-input:disabled:not(.sd-input--disabled) {
3448
3531
  transition: box-shadow var(--sjs-transition-duration, 150ms), background var(--sjs-transition-duration, 150ms);
3449
3532
  }
3450
3533
 
3534
+ .sd-item--readonly.sd-item--readonly .sd-item__decorator {
3535
+ background-color: var(--sjs-questionpanel-hovercolor, var(--sjs-general-backcolor-dark, rgb(248, 248, 248)));
3536
+ box-shadow: none;
3537
+ transition: none;
3538
+ }
3539
+
3540
+ .sd-item--preview.sd-item--preview .sd-item__decorator {
3541
+ background-color: transparent;
3542
+ box-shadow: none;
3543
+ transition: none;
3544
+ }
3545
+
3451
3546
  .sd-item--checked .sd-item__decorator {
3452
3547
  box-shadow: none;
3453
3548
  }
@@ -3575,6 +3670,14 @@ textarea.sd-input:disabled:not(.sd-input--disabled) {
3575
3670
  fill: var(--sjs-primary-backcolor, var(--primary, #19b394));
3576
3671
  }
3577
3672
 
3673
+ .sd-checkbox--checked.sd-checkbox--readonly .sd-checkbox__svg use {
3674
+ fill: var(--sjs-general-forecolor, var(--foreground, #161616));
3675
+ }
3676
+
3677
+ .sd-checkbox--checked.sd-checkbox--preview .sd-checkbox__svg use {
3678
+ fill: var(--sjs-general-forecolor, var(--foreground, #161616));
3679
+ }
3680
+
3578
3681
  .sd-radio__decorator {
3579
3682
  border-radius: 50%;
3580
3683
  }
@@ -3601,6 +3704,20 @@ textarea.sd-input:disabled:not(.sd-input--disabled) {
3601
3704
  background-color: var(--sjs-border-default, var(--border, #d6d6d6));
3602
3705
  }
3603
3706
 
3707
+ .sd-radio--checked.sd-radio--readonly .sd-radio__decorator:after {
3708
+ background-color: var(--sjs-general-forecolor, var(--foreground, #161616));
3709
+ }
3710
+
3711
+ .sd-radio--checked.sd-radio--preview .sd-radio__decorator:after {
3712
+ display: none;
3713
+ }
3714
+ .sd-radio--checked.sd-radio--preview .sd-radio__decorator .sd-radio__svg {
3715
+ fill: var(--sjs-general-forecolor, var(--foreground, #161616));
3716
+ display: block;
3717
+ width: calc(2.5 * (var(--sjs-base-unit, var(--base-unit, 8px))));
3718
+ height: calc(2.5 * (var(--sjs-base-unit, var(--base-unit, 8px))));
3719
+ }
3720
+
3604
3721
  .sd-radio--checked .sd-radio__control:focus + .sd-radio__decorator:after {
3605
3722
  background-color: var(--sjs-primary-backcolor, var(--primary, #19b394));
3606
3723
  }
@@ -3785,6 +3902,43 @@ legend + sv-ng-rating-item + .sd-rating__item {
3785
3902
  border: none;
3786
3903
  }
3787
3904
 
3905
+ .sd-rating__item.sd-rating__item--readonly {
3906
+ fill: transparent;
3907
+ background-color: transparent;
3908
+ border: 2px solid var(--sjs-border-inside, var(--border-inside, rgba(0, 0, 0, 0.16)));
3909
+ box-shadow: none;
3910
+ transform: none;
3911
+ }
3912
+ .sd-rating__item.sd-rating__item--readonly .sd-rating__item-text.sd-rating__item-text {
3913
+ color: var(--sjs-general-forecolor-light, var(--foreground-light, #909090));
3914
+ }
3915
+
3916
+ .sd-rating__item.sd-rating__item--selected.sd-rating__item--readonly {
3917
+ border-color: var(--sjs-general-forecolor, var(--foreground, #161616));
3918
+ }
3919
+ .sd-rating__item.sd-rating__item--selected.sd-rating__item--readonly .sd-rating__item-text.sd-rating__item-text {
3920
+ color: var(--sjs-general-forecolor, var(--foreground, #161616));
3921
+ }
3922
+
3923
+ .sd-rating__item.sd-rating__item--preview {
3924
+ fill: transparent;
3925
+ background-color: transparent;
3926
+ border: 1px solid transparent;
3927
+ box-shadow: none;
3928
+ transform: none;
3929
+ }
3930
+ .sd-rating__item.sd-rating__item--preview .sd-rating__item-text.sd-rating__item-text {
3931
+ color: var(--sjs-general-forecolor, var(--foreground, #161616));
3932
+ }
3933
+
3934
+ .sd-rating__item.sd-rating__item--selected.sd-rating__item--preview {
3935
+ border-color: var(--sjs-general-forecolor, var(--foreground, #161616));
3936
+ border-width: 1px;
3937
+ }
3938
+ .sd-rating__item.sd-rating__item--selected.sd-rating__item--preview .sd-rating__item-text.sd-rating__item-text {
3939
+ color: var(--sjs-general-forecolor, var(--foreground, #161616));
3940
+ }
3941
+
3788
3942
  .sd-question--disabled .sd-rating__item-text {
3789
3943
  opacity: 0.25;
3790
3944
  }
@@ -3870,6 +4024,26 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
3870
4024
  fill: var(--sjs-primary-forecolor, var(--primary-foreground, #fff));
3871
4025
  }
3872
4026
 
4027
+ .sd-rating__item-smiley.sd-rating__item-smiley--selected.sd-rating__item-smiley--readonly {
4028
+ fill: var(--sjs-general-forecolor, var(--foreground, #161616));
4029
+ border-color: var(--sjs-general-forecolor, var(--foreground, #161616));
4030
+ background-color: unset;
4031
+ }
4032
+
4033
+ .sd-rating__item-smiley.sd-rating__item-smiley--preview {
4034
+ border-color: var(--sjs-general-forecolor, var(--foreground, #161616));
4035
+ border-width: 1px;
4036
+ fill: var(--sjs-general-forecolor, var(--foreground, #161616));
4037
+ }
4038
+ .sd-rating__item-smiley.sd-rating__item-smiley--preview svg {
4039
+ margin: 1px;
4040
+ }
4041
+
4042
+ .sd-rating__item-smiley.sd-rating__item-smiley--selected.sd-rating__item-smiley--preview {
4043
+ fill: var(--sjs-general-backcolor, var(--background, #fff));
4044
+ background-color: var(--sjs-general-forecolor, var(--foreground, #161616));
4045
+ }
4046
+
3873
4047
  .sd-rating__item-smiley--allowhover:hover {
3874
4048
  background-color: var(--sjs-questionpanel-hovercolor, var(--sjs-general-backcolor-dark, rgb(248, 248, 248)));
3875
4049
  border-color: var(--sjs-border-default, var(--border, #d6d6d6));
@@ -3905,6 +4079,10 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
3905
4079
  opacity: 1;
3906
4080
  }
3907
4081
 
4082
+ .sd-rating__item-smiley--scale-colored.sd-rating__item-smiley--selected, .sd-rating__item-smiley--scale-colored.sd-rating__item-smiley--readonly, .sd-rating__item-smiley--scale-colored.sd-rating__item-smiley--preview {
4083
+ opacity: 1;
4084
+ }
4085
+
3908
4086
  .sd-rating__item-star {
3909
4087
  position: relative;
3910
4088
  width: calc(6 * (var(--sjs-base-unit, var(--base-unit, 8px))));
@@ -3920,6 +4098,7 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
3920
4098
  }
3921
4099
  .sd-rating__item-star svg {
3922
4100
  stroke: var(--sjs-border-default, var(--border, #d6d6d6));
4101
+ stroke-width: 2px;
3923
4102
  fill: transparent;
3924
4103
  width: calc(6 * (var(--sjs-base-unit, var(--base-unit, 8px))));
3925
4104
  height: calc(6 * (var(--sjs-base-unit, var(--base-unit, 8px))));
@@ -3942,6 +4121,9 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
3942
4121
  width: calc(3 * (var(--sjs-base-unit, var(--base-unit, 8px))));
3943
4122
  height: calc(3 * (var(--sjs-base-unit, var(--base-unit, 8px))));
3944
4123
  }
4124
+ .sd-rating__item-star--small.sd-rating__item-star--selected svg {
4125
+ stroke-width: 1px;
4126
+ }
3945
4127
 
3946
4128
  .sd-rating__item-star--selected svg {
3947
4129
  stroke: transparent;
@@ -3966,6 +4148,27 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
3966
4148
  fill: var(--sjs-border-default, var(--border, #d6d6d6));
3967
4149
  }
3968
4150
 
4151
+ .sd-rating__item-star--readonly svg {
4152
+ stroke: var(--sjs-border-default, var(--border, #d6d6d6));
4153
+ fill: none;
4154
+ }
4155
+
4156
+ .sd-rating__item-star--selected.sd-rating__item-star--readonly svg {
4157
+ stroke: none;
4158
+ fill: var(--sjs-general-forecolor, var(--foreground, #161616));
4159
+ }
4160
+
4161
+ .sd-rating__item-star--preview svg {
4162
+ stroke: var(--sjs-general-forecolor, var(--foreground, #161616));
4163
+ stroke-width: 1px;
4164
+ fill: none;
4165
+ }
4166
+
4167
+ .sd-rating__item-star--selected.sd-rating__item-star--preview svg {
4168
+ stroke: none;
4169
+ fill: var(--sjs-general-forecolor, var(--foreground, #161616));
4170
+ }
4171
+
3969
4172
  .sd-rating__item-star:focus-within svg {
3970
4173
  stroke: var(--sjs-primary-backcolor, var(--primary, #19b394));
3971
4174
  fill: transparent;
@@ -4080,6 +4283,28 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
4080
4283
  left: calc(-3 * (var(--sjs-base-unit, var(--base-unit, 8px))));
4081
4284
  }
4082
4285
 
4286
+ .sv-ranking.sd-ranking--readonly {
4287
+ user-select: initial;
4288
+ -webkit-user-select: initial;
4289
+ }
4290
+ .sv-ranking.sd-ranking--readonly.sv-ranking--select-to-rank-empty-value .sv-ranking__containers-divider {
4291
+ visibility: hidden;
4292
+ }
4293
+ .sv-ranking.sd-ranking--readonly .sv-ranking__container--empty {
4294
+ visibility: hidden;
4295
+ }
4296
+
4297
+ .sv-ranking.sd-ranking--preview {
4298
+ user-select: initial;
4299
+ -webkit-user-select: initial;
4300
+ }
4301
+ .sv-ranking.sd-ranking--preview.sv-ranking--select-to-rank-empty-value .sv-ranking__containers-divider {
4302
+ visibility: hidden;
4303
+ }
4304
+ .sv-ranking.sd-ranking--preview .sv-ranking__container--empty {
4305
+ visibility: hidden;
4306
+ }
4307
+
4083
4308
  @container (max-width: 496px) {
4084
4309
  .sv-ranking--select-to-rank-horizontal {
4085
4310
  flex-direction: column-reverse;
@@ -4306,12 +4531,22 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
4306
4531
  white-space: pre;
4307
4532
  }
4308
4533
 
4309
- .sd-input--disabled .sv-string-viewer {
4534
+ .sd-input--disabled .sv-string-viewer,
4535
+ .sd-input--readonly .sv-string-viewer,
4536
+ .sd-input--preview .sv-string-viewer {
4310
4537
  max-width: 100%;
4311
4538
  overflow: hidden;
4312
4539
  text-overflow: ellipsis;
4313
4540
  }
4314
4541
 
4542
+ .sd-question--readonly .sd-dropdown_chevron-button use {
4543
+ opacity: 0.24;
4544
+ }
4545
+
4546
+ .sd-question--preview .sd-dropdown_chevron-button {
4547
+ display: none;
4548
+ }
4549
+
4315
4550
  .sv-dropdown-popup .sd-list__item-body {
4316
4551
  --sjs-internal-font-editorfont-size: var(--sjs-mobile-font-editorfont-size, var(--sjs-font-editorfont-size, var(--sjs-font-size, 16px)));
4317
4552
  line-height: calc(1.5 * (var(--sjs-internal-font-editorfont-size)));
@@ -4355,14 +4590,14 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
4355
4590
  background-position: left calc(1.5 * (var(--sjs-base-unit, var(--base-unit, 8px)))) top 50%, 0 0;
4356
4591
  }
4357
4592
 
4358
- .sd-input.sd-tagbox:not(.sd-tagbox--empty):not(.sd-input--disabled) {
4593
+ .sd-input.sd-tagbox:not(.sd-tagbox--empty).sd-input--editable {
4359
4594
  height: auto;
4360
4595
  padding: calc(0.5 * (var(--sjs-base-unit, var(--base-unit, 8px))));
4361
4596
  padding-inline-end: calc(6 * (var(--sjs-base-unit, var(--base-unit, 8px))));
4362
4597
  padding-inline-start: calc(0.5 * (var(--sjs-base-unit, var(--base-unit, 8px))));
4363
4598
  }
4364
4599
 
4365
- .sd-tagbox.sd-input--disabled {
4600
+ .sd-tagbox.sd-input--disabled, .sd-tagbox.sd-input--readonly, .sd-tagbox.sd-input--preview {
4366
4601
  white-space: normal;
4367
4602
  }
4368
4603
 
@@ -4629,11 +4864,41 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
4629
4864
  align-items: flex-start;
4630
4865
  padding-right: 0;
4631
4866
  }
4867
+ .sd-imagepicker__column .sd-imagepicker__item {
4868
+ width: 100%;
4869
+ }
4870
+ .sd-imagepicker__column .sd-imagepicker__text {
4871
+ width: 100%;
4872
+ display: inline-block;
4873
+ overflow: hidden;
4874
+ text-overflow: ellipsis;
4875
+ text-align: center;
4876
+ }
4632
4877
 
4633
4878
  .sd-selectbase__column.sd-imagepicker__column:not(:last-child) {
4634
4879
  padding-right: 0;
4635
4880
  }
4636
4881
 
4882
+ .sd-imagepicker__item--readonly .sd-imagepicker__check-icon {
4883
+ fill: var(--sjs-general-forecolor, var(--foreground, #161616));
4884
+ }
4885
+
4886
+ .sd-imagepicker__item--preview .sd-imagepicker__check-decorator {
4887
+ display: none;
4888
+ }
4889
+ .sd-imagepicker__item--preview .sd-imagepicker__image {
4890
+ /* Safari 6.0 - 9.0 */
4891
+ -webkit-filter: grayscale(100%);
4892
+ filter: grayscale(100%);
4893
+ opacity: 0.25;
4894
+ }
4895
+ .sd-imagepicker__item--preview.sd-imagepicker__item--checked .sd-imagepicker__image {
4896
+ /* Safari 6.0 - 9.0 */
4897
+ -webkit-filter: grayscale(0%);
4898
+ filter: grayscale(0%);
4899
+ opacity: 1;
4900
+ }
4901
+
4637
4902
  .sd-image__image {
4638
4903
  display: block;
4639
4904
  max-width: 100%;
@@ -4938,6 +5203,37 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
4938
5203
  opacity: 0.25;
4939
5204
  }
4940
5205
 
5206
+ .sd-boolean--readonly {
5207
+ pointer-events: none;
5208
+ box-shadow: none;
5209
+ transition: none;
5210
+ background: var(--sjs-questionpanel-hovercolor, var(--sjs-general-backcolor-dark, rgb(248, 248, 248)));
5211
+ }
5212
+ .sd-boolean--readonly .sd-boolean__thumb {
5213
+ box-shadow: inset 0px 0px 0px 2px var(--sjs-general-forecolor, var(--foreground, #161616));
5214
+ transition: none;
5215
+ color: var(--sjs-general-forecolor, var(--foreground, #161616));
5216
+ }
5217
+
5218
+ .sd-boolean--preview {
5219
+ pointer-events: none;
5220
+ box-shadow: none;
5221
+ transition: none;
5222
+ background: transparent;
5223
+ }
5224
+ .sd-boolean--preview .sd-boolean__thumb {
5225
+ border: 1px solid var(--sjs-general-forecolor, var(--foreground, #161616));
5226
+ box-shadow: none;
5227
+ transition: none;
5228
+ color: var(--sjs-general-forecolor, var(--foreground, #161616));
5229
+ }
5230
+ .sd-boolean--preview.sd-boolean--checked .sd-boolean__thumb, .sd-boolean--preview.sd-boolean--indeterminate .sd-boolean__thumb {
5231
+ margin-left: auto;
5232
+ }
5233
+ .sd-boolean--preview .sd-checkbox__label--preview {
5234
+ color: var(--sjs-general-forecolor, var(--foreground, #161616));
5235
+ }
5236
+
4941
5237
  .sd-boolean__thumb-ghost {
4942
5238
  z-index: 1;
4943
5239
  border-radius: calc(12.5 * (var(--sjs-base-unit, var(--base-unit, 8px))));
@@ -4976,6 +5272,11 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
4976
5272
  color: var(--sjs-general-forecolor-light, var(--foreground-light, #909090));
4977
5273
  }
4978
5274
 
5275
+ .sd-question--readonly .sd-paneldynamic .sd-question__placeholder,
5276
+ .sd-question--preview .sd-paneldynamic .sd-question__placeholder {
5277
+ color: var(--sjs-general-forecolor, var(--foreground, #161616));
5278
+ }
5279
+
4979
5280
  .sd-paneldynamic__separator {
4980
5281
  display: block;
4981
5282
  position: absolute;
@@ -5374,7 +5675,7 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
5374
5675
  width: 100%;
5375
5676
  }
5376
5677
 
5377
- .sd-file__preview {
5678
+ .sd-file__preview-item {
5378
5679
  position: relative;
5379
5680
  display: flex;
5380
5681
  align-items: stretch;
@@ -5383,13 +5684,13 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
5383
5684
  width: calc(12 * (var(--sjs-base-unit, var(--base-unit, 8px))));
5384
5685
  margin: 0;
5385
5686
  }
5386
- .sd-file__preview .sd-file__default-image {
5687
+ .sd-file__preview-item .sd-file__default-image {
5387
5688
  width: calc(7 * (var(--sjs-base-unit, var(--base-unit, 8px))));
5388
5689
  height: 90px;
5389
5690
  }
5390
- .sd-file__preview img:hover + .sd-file__remove-file-button,
5391
- .sd-file__preview svg:hover + .sd-file__remove-file-button,
5392
- .sd-file__preview .sd-file__remove-file-button:hover {
5691
+ .sd-file__preview-item img:hover + .sd-file__remove-file-button,
5692
+ .sd-file__preview-item svg:hover + .sd-file__remove-file-button,
5693
+ .sd-file__preview-item .sd-file__remove-file-button:hover {
5393
5694
  opacity: 1;
5394
5695
  }
5395
5696
 
@@ -5462,7 +5763,7 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
5462
5763
  .sd-file--single-image {
5463
5764
  height: calc(36 * var(--sjs-base-unit, var(--base-unit, 8px)));
5464
5765
  }
5465
- .sd-file--single-image .sd-file__preview {
5766
+ .sd-file--single-image .sd-file__preview-item {
5466
5767
  width: 100%;
5467
5768
  margin: 0;
5468
5769
  }
@@ -5578,6 +5879,38 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
5578
5879
  cursor: default;
5579
5880
  }
5580
5881
 
5882
+ .sd-file--readonly .sd-context-btn {
5883
+ display: none;
5884
+ }
5885
+ .sd-file--readonly .sd-file__decorator {
5886
+ border-color: transparent;
5887
+ }
5888
+ .sd-file--readonly .sd-file__actions-container {
5889
+ display: none;
5890
+ }
5891
+ .sd-file--readonly .sd-file__image-wrapper {
5892
+ background: var(--sjs-questionpanel-hovercolor, var(--sjs-general-backcolor-dark, rgb(248, 248, 248)));
5893
+ }
5894
+ .sd-file--readonly .sd-file__drag-area-placeholder {
5895
+ color: var(--sjs-general-forecolor, var(--foreground, #161616));
5896
+ }
5897
+
5898
+ .sd-file--preview .sd-context-btn {
5899
+ display: none;
5900
+ }
5901
+ .sd-file--preview .sd-file__decorator {
5902
+ border-color: transparent;
5903
+ }
5904
+ .sd-file--preview .sd-file__image-wrapper {
5905
+ background: transparent;
5906
+ }
5907
+ .sd-file--preview .sd-file__actions-container {
5908
+ display: none;
5909
+ }
5910
+ .sd-file--preview .sd-file__drag-area-placeholder {
5911
+ color: var(--sjs-general-forecolor, var(--foreground, #161616));
5912
+ }
5913
+
5581
5914
  .sd-hidden {
5582
5915
  display: none !important;
5583
5916
  }
@@ -5972,6 +6305,10 @@ legend + sv-ng-rating-item + .sd-rating__item-smiley {
5972
6305
  color: var(--sjs-font-editorfont-placeholdercolor, var(--sjs-general-forecolor-light, var(--foreground-light, #909090)));
5973
6306
  }
5974
6307
 
6308
+ .sd-question--preview .sd-multipletext__item-title {
6309
+ border: none;
6310
+ }
6311
+
5975
6312
  .sd-multipletext__item {
5976
6313
  flex-grow: 1;
5977
6314
  }