@testgorilla/tgo-coding-test 1.0.0 → 2.0.0

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 (353) hide show
  1. package/.eslintrc.json +46 -0
  2. package/jest.config.ts +26 -0
  3. package/ng-package.json +14 -0
  4. package/package.json +15 -31
  5. package/project.json +48 -0
  6. package/{index.d.ts → src/index.ts} +19 -2
  7. package/src/lib/components/.gitkeep +0 -0
  8. package/src/lib/components/code-editor/code-editor.component.html +10 -0
  9. package/src/lib/components/code-editor/code-editor.component.scss +21 -0
  10. package/src/lib/components/code-editor/code-editor.component.spec.ts +136 -0
  11. package/src/lib/components/code-editor/code-editor.component.ts +368 -0
  12. package/src/lib/components/code-editor/code-editor.mocks.ts +28 -0
  13. package/src/lib/components/code-editor/code-editor.service.spec.ts +160 -0
  14. package/src/lib/components/code-editor/code-editor.service.ts +94 -0
  15. package/src/lib/components/code-editor/helpers/c-helper.spec.ts +39 -0
  16. package/src/lib/components/code-editor/helpers/c-helper.ts +51 -0
  17. package/src/lib/components/code-editor/helpers/code-editor-helper.base.spec.ts +30 -0
  18. package/src/lib/components/code-editor/helpers/code-editor-helper.base.ts +16 -0
  19. package/src/lib/components/code-editor/helpers/code-editor-helper.mocks.ts +24 -0
  20. package/src/lib/components/code-editor/helpers/code-editor-helper.model.ts +67 -0
  21. package/src/lib/components/code-editor/helpers/cpp-helper.spec.ts +40 -0
  22. package/src/lib/components/code-editor/helpers/cpp-helper.ts +52 -0
  23. package/src/lib/components/code-editor/helpers/csharp-helper.spec.ts +42 -0
  24. package/src/lib/components/code-editor/helpers/csharp-helper.ts +55 -0
  25. package/src/lib/components/code-editor/helpers/go-helper.spec.ts +41 -0
  26. package/src/lib/components/code-editor/helpers/go-helper.ts +54 -0
  27. package/src/lib/components/code-editor/helpers/java-helper.spec.ts +41 -0
  28. package/src/lib/components/code-editor/helpers/java-helper.ts +54 -0
  29. package/src/lib/components/code-editor/helpers/javascript-helper.spec.ts +39 -0
  30. package/src/lib/components/code-editor/helpers/javascript-helper.ts +32 -0
  31. package/src/lib/components/code-editor/helpers/kotlin-helper.spec.ts +41 -0
  32. package/src/lib/components/code-editor/helpers/kotlin-helper.ts +54 -0
  33. package/src/lib/components/code-editor/helpers/php-helper.spec.ts +39 -0
  34. package/src/lib/components/code-editor/helpers/php-helper.ts +32 -0
  35. package/src/lib/components/code-editor/helpers/python-helper.spec.ts +39 -0
  36. package/src/lib/components/code-editor/helpers/python-helper.ts +32 -0
  37. package/src/lib/components/code-editor/helpers/r-helper.spec.ts +39 -0
  38. package/src/lib/components/code-editor/helpers/r-helper.ts +32 -0
  39. package/src/lib/components/code-editor/helpers/ruby-helper.spec.ts +39 -0
  40. package/src/lib/components/code-editor/helpers/ruby-helper.ts +32 -0
  41. package/src/lib/components/code-editor/helpers/scala-helper.spec.ts +41 -0
  42. package/src/lib/components/code-editor/helpers/scala-helper.ts +53 -0
  43. package/src/lib/components/code-editor/helpers/sql-helper.spec.ts +87 -0
  44. package/src/lib/components/code-editor/helpers/sql-helper.ts +44 -0
  45. package/src/lib/components/code-editor/helpers/swift-helper.spec.ts +40 -0
  46. package/src/lib/components/code-editor/helpers/swift-helper.ts +51 -0
  47. package/src/lib/components/code-editor/helpers/typescript-helper.spec.ts +40 -0
  48. package/src/lib/components/code-editor/helpers/typescript-helper.ts +52 -0
  49. package/src/lib/components/code-editor/models/code-editor.model.ts +9 -0
  50. package/src/lib/components/code-editor/models/coding-snapshot.model.ts +4 -0
  51. package/src/lib/components/coding-question/coding-question.component.html +78 -0
  52. package/src/lib/components/coding-question/coding-question.component.scss +75 -0
  53. package/src/lib/components/coding-question/coding-question.component.spec.ts +85 -0
  54. package/src/lib/components/coding-question/coding-question.component.ts +101 -0
  55. package/src/lib/components/coding-section/coding-section.component.html +82 -0
  56. package/src/lib/components/coding-section/coding-section.component.scss +64 -0
  57. package/src/lib/components/coding-section/coding-section.component.spec.ts +257 -0
  58. package/src/lib/components/coding-section/coding-section.component.ts +186 -0
  59. package/src/lib/components/coding-test.module.ts +124 -0
  60. package/src/lib/components/common/truncated-text/truncated-text.component.html +6 -0
  61. package/src/lib/components/common/truncated-text/truncated-text.component.scss +18 -0
  62. package/src/lib/components/common/truncated-text/truncated-text.component.spec.ts +84 -0
  63. package/src/lib/components/common/truncated-text/truncated-text.component.ts +36 -0
  64. package/src/lib/components/configurations/configurations.component.html +57 -0
  65. package/src/lib/components/configurations/configurations.component.scss +42 -0
  66. package/src/lib/components/configurations/configurations.component.spec.ts +186 -0
  67. package/src/lib/components/configurations/configurations.component.ts +97 -0
  68. package/src/lib/components/instructions/instructions.component.html +41 -0
  69. package/src/lib/components/instructions/instructions.component.scss +173 -0
  70. package/src/lib/components/instructions/instructions.component.spec.ts +106 -0
  71. package/src/lib/components/instructions/instructions.component.ts +137 -0
  72. package/src/lib/components/panel/panel.component.html +19 -0
  73. package/src/lib/components/panel/panel.component.scss +41 -0
  74. package/src/lib/components/panel/panel.component.spec.ts +40 -0
  75. package/src/lib/components/panel/panel.component.ts +33 -0
  76. package/src/lib/components/runnable-editor/runnable-editor.component.html +75 -0
  77. package/src/lib/components/runnable-editor/runnable-editor.component.scss +55 -0
  78. package/src/lib/components/runnable-editor/runnable-editor.component.spec.ts +124 -0
  79. package/src/lib/components/runnable-editor/runnable-editor.component.ts +154 -0
  80. package/src/lib/components/tests/test-cases/test-cases.component.html +135 -0
  81. package/src/lib/components/tests/test-cases/test-cases.component.scss +220 -0
  82. package/src/lib/components/tests/test-cases/test-cases.component.spec.ts +401 -0
  83. package/src/lib/components/tests/test-cases/test-cases.component.ts +204 -0
  84. package/src/lib/components/tests/test-cases-content/test-cases-content.component.html +94 -0
  85. package/src/lib/components/tests/test-cases-content/test-cases-content.component.scss +103 -0
  86. package/src/lib/components/tests/test-cases-content/test-cases-content.component.spec.ts +122 -0
  87. package/src/lib/components/tests/test-cases-content/test-cases-content.component.ts +101 -0
  88. package/src/lib/components/tests/test-cases-status/test-cases-status.component.html +16 -0
  89. package/src/lib/components/tests/test-cases-status/test-cases-status.component.scss +49 -0
  90. package/src/lib/components/tests/test-cases-status/test-cases-status.component.spec.ts +22 -0
  91. package/src/lib/components/tests/test-cases-status/test-cases-status.component.ts +17 -0
  92. package/src/lib/components/tests/test-results.component.html +119 -0
  93. package/src/lib/components/tests/test-results.component.scss +189 -0
  94. package/src/lib/components/tests/test-results.component.spec.ts +140 -0
  95. package/src/lib/components/tests/test-results.component.ts +97 -0
  96. package/src/lib/components/tgo-coding-test/tgo-coding-test.component.html +96 -0
  97. package/src/lib/components/tgo-coding-test/tgo-coding-test.component.scss +6 -0
  98. package/src/lib/components/tgo-coding-test/tgo-coding-test.component.spec.ts +599 -0
  99. package/src/lib/components/tgo-coding-test/tgo-coding-test.component.ts +278 -0
  100. package/src/lib/components/tgo-coding-test-candidate-view/tgo-coding-test-candidate-view.component.html +36 -0
  101. package/src/lib/components/tgo-coding-test-candidate-view/tgo-coding-test-candidate-view.component.scss +183 -0
  102. package/src/lib/components/tgo-coding-test-candidate-view/tgo-coding-test-candidate-view.component.spec.ts +883 -0
  103. package/src/lib/components/tgo-coding-test-candidate-view/tgo-coding-test-candidate-view.component.ts +578 -0
  104. package/{lib/config/index.d.ts → src/lib/config/index.ts} +1 -0
  105. package/src/lib/config/tgo-coding-test.config.ts +26 -0
  106. package/{lib/config/tgo-coding-test.provider.d.ts → src/lib/config/tgo-coding-test.provider.ts} +18 -6
  107. package/src/lib/config/tgo-coding-test.token.ts +21 -0
  108. package/src/lib/models/.gitkeep +0 -0
  109. package/src/lib/models/auto-saved-data.ts +51 -0
  110. package/src/lib/models/code-event.ts +17 -0
  111. package/src/lib/models/coderunner-execution-results.ts +58 -0
  112. package/src/lib/models/coding-lib.mocks.ts +246 -0
  113. package/src/lib/models/configs.ts +18 -0
  114. package/src/lib/models/language-change-action.ts +4 -0
  115. package/src/lib/models/lat-languages.ts +12 -0
  116. package/src/lib/models/mixpanel-events.ts +3 -0
  117. package/src/lib/models/mode.ts +5 -0
  118. package/src/lib/models/paste-data.ts +4 -0
  119. package/src/lib/models/programming-language.ts +9 -0
  120. package/src/lib/models/test-cases.ts +74 -0
  121. package/src/lib/models/theme.ts +5 -0
  122. package/src/lib/models/translations.ts +1 -0
  123. package/src/lib/models/view-mode.ts +6 -0
  124. package/{lib/pipes/memoize-func.pipe.d.ts → src/lib/pipes/memoize-func.pipe.ts} +14 -6
  125. package/src/lib/services/.gitkeep +0 -0
  126. package/src/lib/services/candidate-coding-test-services/candidature-api.service.spec.ts +40 -0
  127. package/src/lib/services/candidate-coding-test-services/candidature-api.service.ts +15 -0
  128. package/src/lib/services/candidate-coding-test-services/coderunner-api.service.spec.ts +134 -0
  129. package/src/lib/services/candidate-coding-test-services/coderunner-api.service.ts +105 -0
  130. package/src/lib/services/candidate-coding-test-services/coding-test-tour.service.spec.ts +161 -0
  131. package/src/lib/services/candidate-coding-test-services/coding-test-tour.service.ts +100 -0
  132. package/src/lib/services/candidate-coding-test-services/coding-test.service.spec.ts +1524 -0
  133. package/src/lib/services/candidate-coding-test-services/coding-test.service.ts +843 -0
  134. package/{lib/services/candidate-coding-test-services/index.d.ts → src/lib/services/candidate-coding-test-services/index.ts} +1 -1
  135. package/src/lib/services/coding-test-config.service.ts +48 -0
  136. package/src/lib/services/configurations.service.mocks.ts +77 -0
  137. package/src/lib/services/configurations.service.spec.ts +79 -0
  138. package/src/lib/services/configurations.service.ts +111 -0
  139. package/src/lib/services/index.ts +0 -0
  140. package/src/lib/services/lib-coding-test.service.spec.ts +265 -0
  141. package/src/lib/services/lib-coding-test.service.ts +157 -0
  142. package/src/lib/services/local-storage.service.mocks.ts +22 -0
  143. package/src/lib/services/storage.service.spec.ts +1119 -0
  144. package/src/lib/services/storage.service.ts +729 -0
  145. package/src/lib/services/test-cases.service.spec.ts +53 -0
  146. package/src/lib/services/test-cases.service.ts +29 -0
  147. package/src/lib/services/theme.service.spec.ts +76 -0
  148. package/src/lib/services/theme.service.ts +34 -0
  149. package/src/lib/styles/mixins.scss +86 -0
  150. package/src/lib/styles/styles.scss +112 -0
  151. package/src/lib/styles/variables.scss +105 -0
  152. package/src/lib/utils/.gitkeep +0 -0
  153. package/src/lib/utils/additional-languages/erlang.ts +115 -0
  154. package/src/lib/utils/resize-element.ts +15 -0
  155. package/src/lib/utils/time-to-ms.util.ts +10 -0
  156. package/src/test-setup.ts +3 -0
  157. package/tsconfig.json +19 -0
  158. package/tsconfig.lib.json +19 -0
  159. package/tsconfig.lib.prod.json +10 -0
  160. package/tsconfig.spec.json +17 -0
  161. package/esm2022/index.mjs +0 -12
  162. package/esm2022/lib/components/code-editor/code-editor.component.mjs +0 -335
  163. package/esm2022/lib/components/code-editor/code-editor.service.mjs +0 -72
  164. package/esm2022/lib/components/code-editor/helpers/c-helper.mjs +0 -40
  165. package/esm2022/lib/components/code-editor/helpers/code-editor-helper.base.mjs +0 -11
  166. package/esm2022/lib/components/code-editor/helpers/code-editor-helper.model.mjs +0 -2
  167. package/esm2022/lib/components/code-editor/helpers/cpp-helper.mjs +0 -41
  168. package/esm2022/lib/components/code-editor/helpers/csharp-helper.mjs +0 -42
  169. package/esm2022/lib/components/code-editor/helpers/go-helper.mjs +0 -42
  170. package/esm2022/lib/components/code-editor/helpers/index.mjs +0 -16
  171. package/esm2022/lib/components/code-editor/helpers/java-helper.mjs +0 -42
  172. package/esm2022/lib/components/code-editor/helpers/javascript-helper.mjs +0 -26
  173. package/esm2022/lib/components/code-editor/helpers/kotlin-helper.mjs +0 -42
  174. package/esm2022/lib/components/code-editor/helpers/php-helper.mjs +0 -26
  175. package/esm2022/lib/components/code-editor/helpers/python-helper.mjs +0 -26
  176. package/esm2022/lib/components/code-editor/helpers/r-helper.mjs +0 -26
  177. package/esm2022/lib/components/code-editor/helpers/ruby-helper.mjs +0 -26
  178. package/esm2022/lib/components/code-editor/helpers/scala-helper.mjs +0 -41
  179. package/esm2022/lib/components/code-editor/helpers/sql-helper.mjs +0 -34
  180. package/esm2022/lib/components/code-editor/helpers/swift-helper.mjs +0 -40
  181. package/esm2022/lib/components/code-editor/helpers/typescript-helper.mjs +0 -41
  182. package/esm2022/lib/components/code-editor/models/code-editor.model.mjs +0 -2
  183. package/esm2022/lib/components/code-editor/models/coding-snapshot.model.mjs +0 -2
  184. package/esm2022/lib/components/coding-question/coding-question.component.mjs +0 -126
  185. package/esm2022/lib/components/coding-section/coding-section.component.mjs +0 -188
  186. package/esm2022/lib/components/common/truncated-text/truncated-text.component.mjs +0 -38
  187. package/esm2022/lib/components/configurations/configurations.component.mjs +0 -97
  188. package/esm2022/lib/components/instructions/instructions.component.mjs +0 -139
  189. package/esm2022/lib/components/panel/panel.component.mjs +0 -34
  190. package/esm2022/lib/components/runnable-editor/runnable-editor.component.mjs +0 -169
  191. package/esm2022/lib/components/tests/test-cases/test-cases.component.mjs +0 -198
  192. package/esm2022/lib/components/tests/test-cases-content/test-cases-content.component.mjs +0 -96
  193. package/esm2022/lib/components/tests/test-cases-status/test-cases-status.component.mjs +0 -21
  194. package/esm2022/lib/components/tests/test-results.component.mjs +0 -127
  195. package/esm2022/lib/components/tgo-coding-test/tgo-coding-test.component.mjs +0 -280
  196. package/esm2022/lib/components/tgo-coding-test-candidate-view/tgo-coding-test-candidate-view.component.mjs +0 -476
  197. package/esm2022/lib/config/index.mjs +0 -2
  198. package/esm2022/lib/config/tgo-coding-test.config.mjs +0 -2
  199. package/esm2022/lib/config/tgo-coding-test.provider.mjs +0 -34
  200. package/esm2022/lib/config/tgo-coding-test.token.mjs +0 -14
  201. package/esm2022/lib/models/auto-saved-data.mjs +0 -2
  202. package/esm2022/lib/models/code-event.mjs +0 -2
  203. package/esm2022/lib/models/coderunner-execution-results.mjs +0 -2
  204. package/esm2022/lib/models/configs.mjs +0 -2
  205. package/esm2022/lib/models/language-change-action.mjs +0 -2
  206. package/esm2022/lib/models/lat-languages.mjs +0 -3
  207. package/esm2022/lib/models/mixpanel-events.mjs +0 -2
  208. package/esm2022/lib/models/mode.mjs +0 -2
  209. package/esm2022/lib/models/paste-data.mjs +0 -2
  210. package/esm2022/lib/models/programming-language.mjs +0 -2
  211. package/esm2022/lib/models/test-cases.mjs +0 -7
  212. package/esm2022/lib/models/theme.mjs +0 -2
  213. package/esm2022/lib/models/translations.mjs +0 -2
  214. package/esm2022/lib/models/view-mode.mjs +0 -8
  215. package/esm2022/lib/pipes/memoize-func.pipe.mjs +0 -39
  216. package/esm2022/lib/services/candidate-coding-test-services/candidature-api.service.mjs +0 -19
  217. package/esm2022/lib/services/candidate-coding-test-services/coderunner-api.service.mjs +0 -58
  218. package/esm2022/lib/services/candidate-coding-test-services/coding-test-tour.service.mjs +0 -89
  219. package/esm2022/lib/services/candidate-coding-test-services/coding-test.service.mjs +0 -490
  220. package/esm2022/lib/services/candidate-coding-test-services/index.mjs +0 -5
  221. package/esm2022/lib/services/coding-test-config.service.mjs +0 -51
  222. package/esm2022/lib/services/configurations.service.mjs +0 -89
  223. package/esm2022/lib/services/lib-coding-test.service.mjs +0 -106
  224. package/esm2022/lib/services/storage.service.mjs +0 -624
  225. package/esm2022/lib/services/test-cases.service.mjs +0 -30
  226. package/esm2022/lib/services/theme.service.mjs +0 -36
  227. package/esm2022/lib/utils/additional-languages/erlang.mjs +0 -103
  228. package/esm2022/lib/utils/resize-element.mjs +0 -13
  229. package/esm2022/lib/utils/time-to-ms.util.mjs +0 -11
  230. package/esm2022/shared/index.mjs +0 -5
  231. package/esm2022/shared/lib/components/audio-animation/audio-animation.component.mjs +0 -114
  232. package/esm2022/shared/lib/components/audio-animation/index.mjs +0 -2
  233. package/esm2022/shared/lib/components/index.mjs +0 -3
  234. package/esm2022/shared/lib/components/vimeo-video/index.mjs +0 -2
  235. package/esm2022/shared/lib/components/vimeo-video/vimeo-video.component.mjs +0 -101
  236. package/esm2022/shared/lib/models/answer.mjs +0 -2
  237. package/esm2022/shared/lib/models/assessment.mjs +0 -2
  238. package/esm2022/shared/lib/models/environment.mjs +0 -2
  239. package/esm2022/shared/lib/models/index.mjs +0 -9
  240. package/esm2022/shared/lib/models/question-component.mjs +0 -2
  241. package/esm2022/shared/lib/models/question.mjs +0 -2
  242. package/esm2022/shared/lib/models/test.mjs +0 -2
  243. package/esm2022/shared/lib/models/translations.mjs +0 -2
  244. package/esm2022/shared/lib/models/window.mjs +0 -2
  245. package/esm2022/shared/lib/services/api/api.service.mjs +0 -97
  246. package/esm2022/shared/lib/services/api/mocked-api.service.mjs +0 -131
  247. package/esm2022/shared/lib/services/environment/environment.service.mjs +0 -13
  248. package/esm2022/shared/lib/services/index.mjs +0 -10
  249. package/esm2022/shared/lib/services/localization/languages.model.mjs +0 -19
  250. package/esm2022/shared/lib/services/localization/transloco-lazy-module-utils.mjs +0 -27
  251. package/esm2022/shared/lib/services/localization/transloco-testing.module.mjs +0 -11
  252. package/esm2022/shared/lib/services/media/media.service.mjs +0 -129
  253. package/esm2022/shared/lib/services/mixpanel/mixpanel.service.mjs +0 -30
  254. package/esm2022/shared/lib/services/theme/theme.service.mjs +0 -24
  255. package/esm2022/shared/test-mocks/assessment-test.mock.mjs +0 -112
  256. package/esm2022/shared/test-mocks/index.mjs +0 -3
  257. package/esm2022/shared/test-mocks/tgo-ui.mock.mjs +0 -39
  258. package/esm2022/testgorilla-tgo-coding-test.mjs +0 -5
  259. package/fesm2022/testgorilla-tgo-coding-test.mjs +0 -4526
  260. package/fesm2022/testgorilla-tgo-coding-test.mjs.map +0 -1
  261. package/lib/components/code-editor/code-editor.component.d.ts +0 -54
  262. package/lib/components/code-editor/code-editor.service.d.ts +0 -12
  263. package/lib/components/code-editor/helpers/c-helper.d.ts +0 -11
  264. package/lib/components/code-editor/helpers/code-editor-helper.base.d.ts +0 -8
  265. package/lib/components/code-editor/helpers/code-editor-helper.model.d.ts +0 -62
  266. package/lib/components/code-editor/helpers/cpp-helper.d.ts +0 -11
  267. package/lib/components/code-editor/helpers/csharp-helper.d.ts +0 -12
  268. package/lib/components/code-editor/helpers/go-helper.d.ts +0 -12
  269. package/lib/components/code-editor/helpers/java-helper.d.ts +0 -12
  270. package/lib/components/code-editor/helpers/javascript-helper.d.ts +0 -10
  271. package/lib/components/code-editor/helpers/kotlin-helper.d.ts +0 -12
  272. package/lib/components/code-editor/helpers/php-helper.d.ts +0 -10
  273. package/lib/components/code-editor/helpers/python-helper.d.ts +0 -10
  274. package/lib/components/code-editor/helpers/r-helper.d.ts +0 -10
  275. package/lib/components/code-editor/helpers/ruby-helper.d.ts +0 -10
  276. package/lib/components/code-editor/helpers/scala-helper.d.ts +0 -12
  277. package/lib/components/code-editor/helpers/sql-helper.d.ts +0 -10
  278. package/lib/components/code-editor/helpers/swift-helper.d.ts +0 -11
  279. package/lib/components/code-editor/helpers/typescript-helper.d.ts +0 -11
  280. package/lib/components/code-editor/models/code-editor.model.d.ts +0 -8
  281. package/lib/components/code-editor/models/coding-snapshot.model.d.ts +0 -4
  282. package/lib/components/coding-question/coding-question.component.d.ts +0 -45
  283. package/lib/components/coding-section/coding-section.component.d.ts +0 -52
  284. package/lib/components/common/truncated-text/truncated-text.component.d.ts +0 -13
  285. package/lib/components/configurations/configurations.component.d.ts +0 -40
  286. package/lib/components/instructions/instructions.component.d.ts +0 -48
  287. package/lib/components/panel/panel.component.d.ts +0 -12
  288. package/lib/components/runnable-editor/runnable-editor.component.d.ts +0 -53
  289. package/lib/components/tests/test-cases/test-cases.component.d.ts +0 -46
  290. package/lib/components/tests/test-cases-content/test-cases-content.component.d.ts +0 -26
  291. package/lib/components/tests/test-cases-status/test-cases-status.component.d.ts +0 -9
  292. package/lib/components/tests/test-results.component.d.ts +0 -33
  293. package/lib/components/tgo-coding-test/tgo-coding-test.component.d.ts +0 -69
  294. package/lib/components/tgo-coding-test-candidate-view/tgo-coding-test-candidate-view.component.d.ts +0 -101
  295. package/lib/config/tgo-coding-test.config.d.ts +0 -24
  296. package/lib/config/tgo-coding-test.token.d.ts +0 -9
  297. package/lib/models/auto-saved-data.d.ts +0 -42
  298. package/lib/models/code-event.d.ts +0 -15
  299. package/lib/models/coderunner-execution-results.d.ts +0 -51
  300. package/lib/models/configs.d.ts +0 -15
  301. package/lib/models/language-change-action.d.ts +0 -4
  302. package/lib/models/lat-languages.d.ts +0 -8
  303. package/lib/models/mixpanel-events.d.ts +0 -3
  304. package/lib/models/mode.d.ts +0 -5
  305. package/lib/models/paste-data.d.ts +0 -4
  306. package/lib/models/programming-language.d.ts +0 -8
  307. package/lib/models/test-cases.d.ts +0 -67
  308. package/lib/models/theme.d.ts +0 -4
  309. package/lib/models/translations.d.ts +0 -1
  310. package/lib/models/view-mode.d.ts +0 -6
  311. package/lib/services/candidate-coding-test-services/candidature-api.service.d.ts +0 -10
  312. package/lib/services/candidate-coding-test-services/coderunner-api.service.d.ts +0 -18
  313. package/lib/services/candidate-coding-test-services/coding-test-tour.service.d.ts +0 -22
  314. package/lib/services/candidate-coding-test-services/coding-test.service.d.ts +0 -68
  315. package/lib/services/coding-test-config.service.d.ts +0 -38
  316. package/lib/services/configurations.service.d.ts +0 -37
  317. package/lib/services/lib-coding-test.service.d.ts +0 -69
  318. package/lib/services/storage.service.d.ts +0 -83
  319. package/lib/services/test-cases.service.d.ts +0 -12
  320. package/lib/services/theme.service.d.ts +0 -17
  321. package/lib/utils/additional-languages/erlang.d.ts +0 -37
  322. package/lib/utils/resize-element.d.ts +0 -2
  323. package/lib/utils/time-to-ms.util.d.ts +0 -1
  324. package/shared/index.d.ts +0 -4
  325. package/shared/lib/components/audio-animation/audio-animation.component.d.ts +0 -27
  326. package/shared/lib/components/audio-animation/index.d.ts +0 -1
  327. package/shared/lib/components/index.d.ts +0 -2
  328. package/shared/lib/components/vimeo-video/index.d.ts +0 -1
  329. package/shared/lib/components/vimeo-video/vimeo-video.component.d.ts +0 -24
  330. package/shared/lib/models/answer.d.ts +0 -17
  331. package/shared/lib/models/assessment.d.ts +0 -80
  332. package/shared/lib/models/environment.d.ts +0 -1
  333. package/shared/lib/models/index.d.ts +0 -8
  334. package/shared/lib/models/question-component.d.ts +0 -54
  335. package/shared/lib/models/question.d.ts +0 -102
  336. package/shared/lib/models/test.d.ts +0 -81
  337. package/shared/lib/models/translations.d.ts +0 -1
  338. package/shared/lib/models/window.d.ts +0 -6
  339. package/shared/lib/services/api/api.service.d.ts +0 -25
  340. package/shared/lib/services/api/mocked-api.service.d.ts +0 -35
  341. package/shared/lib/services/environment/environment.service.d.ts +0 -6
  342. package/shared/lib/services/index.d.ts +0 -9
  343. package/shared/lib/services/localization/languages.model.d.ts +0 -15
  344. package/shared/lib/services/localization/transloco-lazy-module-utils.d.ts +0 -11
  345. package/shared/lib/services/localization/transloco-testing.module.d.ts +0 -2
  346. package/shared/lib/services/media/media.service.d.ts +0 -29
  347. package/shared/lib/services/mixpanel/mixpanel.service.d.ts +0 -10
  348. package/shared/lib/services/theme/theme.service.d.ts +0 -8
  349. package/shared/test-mocks/assessment-test.mock.d.ts +0 -21
  350. package/shared/test-mocks/index.d.ts +0 -2
  351. package/shared/test-mocks/tgo-ui.mock.d.ts +0 -21
  352. /package/{assets → src/assets}/i18n/en.json +0 -0
  353. /package/{lib/components/code-editor/helpers/index.d.ts → src/lib/components/code-editor/helpers/index.ts} +0 -0
@@ -0,0 +1,40 @@
1
+ import { defaultFuncParams } from './code-editor-helper.mocks';
2
+ import { CodeEditorTypescriptHelper } from './typescript-helper';
3
+
4
+ describe('CodeEditorTypescriptHelper', () => {
5
+ let helper: CodeEditorTypescriptHelper;
6
+
7
+ const defaultParams = { ...defaultFuncParams };
8
+ const paramsList =
9
+ 'param1: boolean, param2: number, param3: number, param4: number, param5: string, param6: Array<boolean>, param7: Array<number>, param8: Array<number>';
10
+ const correctFuncOpening = `export default function mockFunction(${paramsList}): boolean {\n`;
11
+ const correctInitCode = `${correctFuncOpening}\t //Insert your code here \n}`;
12
+
13
+ beforeEach(() => {
14
+ helper = new CodeEditorTypescriptHelper(defaultParams);
15
+ });
16
+
17
+ describe('when getting init code', () => {
18
+ let result: string;
19
+
20
+ beforeEach(() => {
21
+ result = helper.getInitCode();
22
+ });
23
+
24
+ it('should return proper init code', () => {
25
+ expect(result).toEqual(correctInitCode);
26
+ });
27
+ });
28
+
29
+ describe('when getting func opening', () => {
30
+ let result: string;
31
+
32
+ beforeEach(() => {
33
+ result = helper.getFunctionOpening();
34
+ });
35
+
36
+ it('should return proper func opening', () => {
37
+ expect(result).toEqual(correctFuncOpening);
38
+ });
39
+ });
40
+ });
@@ -0,0 +1,52 @@
1
+ import { CodeEditorHelperBase } from './code-editor-helper.base';
2
+ import {
3
+ CodeEditorFuncOptions,
4
+ CodeEditorHelper,
5
+ CodeEditorLanguages,
6
+ CodeEditorTypesMap,
7
+ } from './code-editor-helper.model';
8
+
9
+ export class CodeEditorTypescriptHelper extends CodeEditorHelperBase implements CodeEditorHelper {
10
+ language = CodeEditorLanguages.Typescript;
11
+ typesMap: CodeEditorTypesMap = {
12
+ boolean: 'boolean',
13
+ int: 'number',
14
+ number: 'number',
15
+ double: 'number',
16
+ float: 'number',
17
+ str: 'string',
18
+ array_boolean: 'Array<boolean>',
19
+ array_int: 'Array<number>',
20
+ array_float: 'Array<number>',
21
+ array_double: 'Array<number>',
22
+ array_str: 'Array<string>',
23
+ };
24
+
25
+ constructor(private functionOptions: CodeEditorFuncOptions) {
26
+ super();
27
+ }
28
+
29
+ getInitCode(): string {
30
+ return `${this.getFunctionOpening()}\t //Insert your code here \n}`;
31
+ }
32
+
33
+ getFunctionOpening(): string {
34
+ const { name: funcName, returnType } = this.functionOptions;
35
+ const params = this.getParamsString();
36
+ const showingReturnType = this.parseType(returnType);
37
+
38
+ return `export default function ${funcName}(${params}): ${showingReturnType} {\n`;
39
+ }
40
+
41
+ private getParamsString(): string {
42
+ const { params } = this.functionOptions;
43
+ let paramsString = '';
44
+
45
+ if (params && params.length > 0) {
46
+ params.forEach(values => (paramsString += `${values.name}: ${this.parseType(values.type)}, `));
47
+ paramsString = paramsString.slice(0, -2);
48
+ }
49
+
50
+ return paramsString;
51
+ }
52
+ }
@@ -0,0 +1,9 @@
1
+ export interface PasteData {
2
+ type: string;
3
+ data: string;
4
+ }
5
+
6
+ export const enum MonacoColorTheme {
7
+ Light = 'vs',
8
+ Dark = 'vs-dark',
9
+ }
@@ -0,0 +1,4 @@
1
+ export interface CodingSnapshot {
2
+ text: string;
3
+ copied_text?: string;
4
+ }
@@ -0,0 +1,78 @@
1
+ <div
2
+ *ngIf="!isMobile; else mobileTpl"
3
+ class="main-container"
4
+ [ngClass]="{ 'main-container-fullscreen': isFullscreenMode }"
5
+ >
6
+ <mat-card appearance="outlined" class="main-card">
7
+ <as-split class="as-split" direction="horizontal" [useTransition]="true" [gutterSize]="GUTTER_SIZE">
8
+ <as-split-area size="38" minSize="24">
9
+ <ng-container [ngTemplateOutlet]="instructions"></ng-container>
10
+ </as-split-area>
11
+ <as-split-area size="62" minSize="30">
12
+ <ng-container [ngTemplateOutlet]="runnableIde"></ng-container>
13
+ </as-split-area>
14
+ </as-split>
15
+
16
+ <ui-button
17
+ *ngIf="!isFullscreenMode"
18
+ class="fullscreen-btn themed-button"
19
+ [variant]="'secondary'"
20
+ [iconName]="'Full-screen'"
21
+ [justIcon]="true"
22
+ [size]="'big'"
23
+ [applicationTheme]="applicationTheme"
24
+ [tooltip]="translations['TOOLTIPS']['MAXIMISE']"
25
+ [tooltipPosition]="'left'"
26
+ (buttonClickEvent)="enableFullScreenMode()"
27
+ >
28
+ </ui-button>
29
+ </mat-card>
30
+ </div>
31
+
32
+ <ng-template #mobileTpl>
33
+ <div class="main-container main-container-mobile">
34
+ <mat-card appearance="outlined" class="main-card main-card-mobile">
35
+ <ng-container [ngTemplateOutlet]="instructions"></ng-container>
36
+ <ng-container [ngTemplateOutlet]="runnableIde"></ng-container>
37
+ </mat-card>
38
+ </div>
39
+ </ng-template>
40
+
41
+ <ng-template #instructions>
42
+ <tgo-code-instructions
43
+ [mode]="mode"
44
+ [isLAT]="isLAT"
45
+ [questionText]="questionText"
46
+ [translations]="translations"
47
+ [isDarkTheme]="isDarkTheme$ | async"
48
+ ></tgo-code-instructions>
49
+ </ng-template>
50
+ <ng-template #runnableIde>
51
+ <tgo-runnable-editor
52
+ [initCode]="initCode"
53
+ [functionParams]="functionParams"
54
+ [functionName]="functionName"
55
+ [returnType]="returnType"
56
+ [isFullViewMode]="true"
57
+ [shouldGenerateInitCode]="false"
58
+ [isLAT]="isLAT"
59
+ [isSQL]="isSQL"
60
+ [canAddCustomTestCases]="canAddCustomTestCases"
61
+ [languages]="languages"
62
+ [autoHeight]="autoHeight"
63
+ [translations]="translations"
64
+ [questionText]="questionText"
65
+ [companyColor]="companyColor"
66
+ [testCasesStatus]="testCasesStatus"
67
+ [loading]="loading"
68
+ [runTestResponse]="runTestResponse"
69
+ [exampleTestCases]="exampleTestCases"
70
+ [hideTestCases]="hideTestCases"
71
+ [applicationTheme]="applicationTheme"
72
+ (pasteEvent)="pasteEvent.emit($event)"
73
+ (codeChange)="codeChange.emit($event)"
74
+ (runTestClick)="runTestClick.emit($event)"
75
+ (languageChange)="languageChange.emit($event)"
76
+ >
77
+ </tgo-runnable-editor>
78
+ </ng-template>
@@ -0,0 +1,75 @@
1
+ @import '../../styles/mixins';
2
+
3
+ @include as-split-styles();
4
+
5
+ :host {
6
+ display: block;
7
+ height: 100%;
8
+ }
9
+
10
+ .main-container {
11
+ height: 100%;
12
+ padding: 32px 50px 40px 50px;
13
+ display: flex;
14
+ justify-content: center;
15
+
16
+ &-mobile {
17
+ padding: 20px 16px 0;
18
+ }
19
+
20
+ .main-card {
21
+ flex: 1 0 100%;
22
+ height: 100%;
23
+ max-height: 750px;
24
+ max-width: 1280px;
25
+ padding: 0 !important;
26
+ box-shadow: 0 8px 24px 4px rgba(0, 0, 0, 0.08);
27
+ background-color: var(--bg-mat-card) !important;
28
+
29
+ &-mobile {
30
+ display: flex;
31
+ flex-direction: column;
32
+ max-width: 100%;
33
+ max-height: 100%;
34
+ }
35
+ }
36
+
37
+ &-fullscreen {
38
+ padding: 0;
39
+
40
+ .main-card {
41
+ max-height: calc(100vh - 80px);
42
+ max-width: 100vw;
43
+ }
44
+ }
45
+ }
46
+
47
+ .fullscreen-btn {
48
+ position: absolute;
49
+ top: 0;
50
+ right: -50px;
51
+
52
+ &.themed-button {
53
+ ::ng-deep {
54
+ .mat-mdc-unelevated-button.secondary {
55
+ background-color: var(--button-bg-color);
56
+ }
57
+ }
58
+ }
59
+
60
+ @media screen and (min-width: 1400px) {
61
+ right: -72px;
62
+ }
63
+
64
+ .fullscreen-icon {
65
+ width: 18px;
66
+ height: 18px;
67
+ min-width: auto;
68
+ min-height: auto;
69
+ font-size: 18px;
70
+
71
+ ::ng-deep svg {
72
+ fill: var(--icon-bg-color);
73
+ }
74
+ }
75
+ }
@@ -0,0 +1,85 @@
1
+ import { ChangeDetectorRef, NO_ERRORS_SCHEMA } from '@angular/core';
2
+ import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
3
+
4
+ import { MockModule, MockProvider } from 'ng-mocks';
5
+ import { Subject } from 'rxjs';
6
+ import { Themes } from '../../models/theme';
7
+ import { ConfigurationsService } from '../../services/configurations.service';
8
+ import { LibCodingTestService } from '../../services/lib-coding-test.service';
9
+ import { CodingQuestionComponent } from './coding-question.component';
10
+ import { CONFIGURATIONS_SERVICE_MOCK } from '../../services/configurations.service.mocks';
11
+ import { AngularSplitModule } from 'angular-split';
12
+ import { MatCardModule } from '@angular/material/card';
13
+ import { ButtonComponentModule } from '@testgorilla/tgo-ui';
14
+
15
+ describe('CodingQuestionComponent', () => {
16
+ let component: CodingQuestionComponent;
17
+ let fixture: ComponentFixture<CodingQuestionComponent>;
18
+ let configurationsService: ConfigurationsService;
19
+
20
+ beforeEach(waitForAsync(() => {
21
+ TestBed.configureTestingModule({
22
+ imports: [
23
+ CodingQuestionComponent,
24
+ MockModule(AngularSplitModule),
25
+ MockModule(MatCardModule),
26
+ MockModule(ButtonComponentModule),
27
+ ],
28
+ schemas: [NO_ERRORS_SCHEMA],
29
+ providers: [
30
+ MockProvider(ChangeDetectorRef),
31
+ MockProvider(LibCodingTestService, {
32
+ isFullscreen$: new Subject(),
33
+ setFullscreen(val) {
34
+ this.isFullscreen$.next(val);
35
+ },
36
+ }),
37
+ MockProvider(ConfigurationsService, CONFIGURATIONS_SERVICE_MOCK),
38
+ ],
39
+ })
40
+ .overrideComponent(CodingQuestionComponent, {
41
+ set: {
42
+ template: '',
43
+ },
44
+ })
45
+ .compileComponents();
46
+ }));
47
+
48
+ beforeEach(() => {
49
+ fixture = TestBed.createComponent(CodingQuestionComponent);
50
+ configurationsService = TestBed.inject(ConfigurationsService);
51
+ component = fixture.componentInstance;
52
+ component.translations = { TOOLTIPS: {} };
53
+
54
+ fixture.detectChanges();
55
+ });
56
+
57
+ describe('when the fullscreen mode is enabled', () => {
58
+ beforeEach(() => {
59
+ component.enableFullScreenMode();
60
+ });
61
+
62
+ it('should turn on fullscreen mode', () => {
63
+ expect(component.isFullscreenMode).toBeTruthy();
64
+ });
65
+ });
66
+
67
+ describe('when the component is destroyed', () => {
68
+ let setCodeComponentDestroyedSpy: jest.SpyInstance;
69
+ let setColorThemeSpy: jest.SpyInstance;
70
+ let closeConfigPanelSpy: jest.SpyInstance;
71
+
72
+ beforeEach(() => {
73
+ setCodeComponentDestroyedSpy = jest.spyOn(configurationsService, 'setCodeComponentDestroyed');
74
+ setColorThemeSpy = jest.spyOn(configurationsService, 'setColorTheme');
75
+ closeConfigPanelSpy = jest.spyOn(configurationsService, 'closeConfigPanel');
76
+ component.ngOnDestroy();
77
+ });
78
+
79
+ it('should call configurationsService methods', () => {
80
+ expect(setCodeComponentDestroyedSpy).toHaveBeenCalledWith(true);
81
+ expect(setColorThemeSpy).toHaveBeenCalledWith(Themes.Default);
82
+ expect(closeConfigPanelSpy).toHaveBeenCalled();
83
+ });
84
+ });
85
+ });
@@ -0,0 +1,101 @@
1
+ import {
2
+ ChangeDetectionStrategy,
3
+ ChangeDetectorRef,
4
+ Component,
5
+ EventEmitter,
6
+ inject,
7
+ Input,
8
+ OnDestroy,
9
+ OnInit,
10
+ Output,
11
+ } from '@angular/core';
12
+ import { CommonModule } from '@angular/common';
13
+ import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
14
+ import { map } from 'rxjs';
15
+ import { MatCardModule } from '@angular/material/card';
16
+ import { AngularSplitModule } from 'angular-split';
17
+ import { ApplicationTheme, ButtonComponentModule } from '@testgorilla/tgo-ui';
18
+ import { LATLanguages } from '../../models/lat-languages';
19
+ import { Modes } from '../../models/mode';
20
+ import { ExampleTestCase } from '../../models/test-cases';
21
+ import { Themes } from '../../models/theme';
22
+ import { ConfigurationsService } from '../../services/configurations.service';
23
+ import { LibCodingTestService } from '../../services/lib-coding-test.service';
24
+ import {
25
+ CodeEditorFuncParam,
26
+ CodeEditorLanguages,
27
+ CodeEditorTypesMap,
28
+ } from '../code-editor/helpers/code-editor-helper.model';
29
+ import { PasteData } from '../code-editor/models/code-editor.model';
30
+ import { InstructionsComponent } from '../instructions/instructions.component';
31
+ import { RunnableEditorComponent } from '../runnable-editor/runnable-editor.component';
32
+
33
+ @UntilDestroy()
34
+ @Component({
35
+ selector: 'tgo-coding-question',
36
+ templateUrl: './coding-question.component.html',
37
+ styleUrls: ['./coding-question.component.scss'],
38
+ changeDetection: ChangeDetectionStrategy.OnPush,
39
+ imports: [
40
+ CommonModule,
41
+ MatCardModule,
42
+ AngularSplitModule,
43
+ ButtonComponentModule,
44
+ InstructionsComponent,
45
+ RunnableEditorComponent,
46
+ ]
47
+ })
48
+ export class CodingQuestionComponent implements OnInit, OnDestroy {
49
+ private readonly changeDetectorRef = inject(ChangeDetectorRef);
50
+ private readonly libCodingTestService = inject(LibCodingTestService);
51
+ private readonly configurationsService = inject(ConfigurationsService);
52
+
53
+ @Input() initCode: string;
54
+ @Input() functionParams: CodeEditorFuncParam[];
55
+ @Input() functionName: string;
56
+ @Input() returnType: keyof CodeEditorTypesMap;
57
+ @Input() isLAT: boolean;
58
+ @Input() isSQL: boolean;
59
+ @Input() canAddCustomTestCases: boolean;
60
+ @Input() languages: LATLanguages;
61
+ @Input() autoHeight: boolean;
62
+ @Input() translations: Record<string, unknown>;
63
+ @Input() questionText: string;
64
+ @Input() mode: Modes;
65
+ @Input() companyColor: string;
66
+ @Input() testCasesStatus: any;
67
+ @Input() loading: boolean;
68
+ @Input() hideTestCases: boolean;
69
+ @Input() runTestResponse = [];
70
+ @Input() exampleTestCases: ExampleTestCase[];
71
+ @Input() applicationTheme: ApplicationTheme;
72
+
73
+ @Output() pasteEvent = new EventEmitter<PasteData>();
74
+ @Output() codeChange = new EventEmitter<string>();
75
+ @Output() runTestClick = new EventEmitter<boolean>();
76
+ @Output() languageChange = new EventEmitter<CodeEditorLanguages>();
77
+
78
+ isMobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);
79
+
80
+ isFullscreenMode: boolean;
81
+
82
+ GUTTER_SIZE = 1;
83
+
84
+ isDarkTheme$ = this.configurationsService.colorTheme$.pipe(map(theme => theme === Themes.Dark));
85
+
86
+ ngOnInit(): void {
87
+ this.libCodingTestService.isFullscreen$.pipe(untilDestroyed(this)).subscribe(isFullscreen => {
88
+ this.isFullscreenMode = isFullscreen;
89
+ });
90
+ }
91
+
92
+ ngOnDestroy(): void {
93
+ this.configurationsService.setCodeComponentDestroyed(true);
94
+ this.configurationsService.setColorTheme(Themes.Default);
95
+ this.configurationsService.closeConfigPanel();
96
+ }
97
+
98
+ enableFullScreenMode(): void {
99
+ this.libCodingTestService.setFullscreen(true);
100
+ }
101
+ }
@@ -0,0 +1,82 @@
1
+ <section class="section">
2
+ <header *ngIf="isFullViewMode || isRunnableWithLangSelector" class="section-header">
3
+ <h2 class="heading">{{ translations['HEADINGS']['CODING'] }}</h2>
4
+ <div class="header-controls" [class.is-full-screen]="isFullscreenMode$ | async">
5
+ <form *ngIf="isLAT" [formGroup]="headerForm" class="header-form">
6
+ <ui-tooltip [message]="languages.length === 1 ? translations['TOOLTIPS']['DISABLE_LANGUAGE'] : null">
7
+ <ui-dropdown
8
+ id="language-dropdown"
9
+ class="language-dropdown"
10
+ formControlName="language"
11
+ [valueList]="languagesFormattedList"
12
+ [showBottomContent]="false"
13
+ [allowClear]="false"
14
+ [applicationTheme]="applicationTheme"
15
+ ></ui-dropdown>
16
+ </ui-tooltip>
17
+ </form>
18
+ <ui-button
19
+ [variant]="'icon-button'"
20
+ [iconName]="'Reset'"
21
+ [tooltip]="translations['TOOLTIPS']['RESET_CODE']"
22
+ [disabled]="hasNoCodeChanges"
23
+ [applicationTheme]="applicationTheme"
24
+ (buttonClickEvent)="resetCode()"
25
+ class="themed-button"
26
+ >
27
+ </ui-button>
28
+ <ui-button
29
+ *ngIf="isLAT && !isMobile && !isRunnableWithLangSelector"
30
+ [variant]="'icon-button'"
31
+ [iconName]="'Help'"
32
+ [tooltip]="translations['TOOLTIPS']['HELP']"
33
+ [applicationTheme]="applicationTheme"
34
+ (buttonClickEvent)="startGuidedTour()"
35
+ class="themed-button"
36
+ >
37
+ </ui-button>
38
+ <ui-button
39
+ *ngIf="!isRunnableWithLangSelector"
40
+ [variant]="'icon-button'"
41
+ [iconName]="'Settings'"
42
+ [tooltip]="translations['TOOLTIPS']['CONFIGURATIONS']"
43
+ [applicationTheme]="applicationTheme"
44
+ id="configuration-ide-button"
45
+ class="themed-button"
46
+ (buttonClickEvent)="openConfigPanel()"
47
+ >
48
+ </ui-button>
49
+
50
+ <ui-button
51
+ *ngIf="(isFullscreenMode$ | async) && !isMobile"
52
+ [variant]="'icon-button'"
53
+ [iconName]="'Minimize'"
54
+ [tooltip]="translations['TOOLTIPS']['MINIMIZE']"
55
+ [tooltipPosition]="'left'"
56
+ [applicationTheme]="applicationTheme"
57
+ class="themed-button"
58
+ (buttonClickEvent)="disableFullscreen()"
59
+ >
60
+ </ui-button>
61
+ </div>
62
+ </header>
63
+
64
+ <div class="ide" [class.spinner]="isLAT | memoizeFunc: isCodeLoading$ : this | async">
65
+ <tgo-code-editor
66
+ *ngIf="(isLAT | memoizeFunc: isCodeLoading$ : this | async) === false; else showSpinner"
67
+ [initCode]="initCode"
68
+ [functionParams]="functionParams"
69
+ [functionName]="functionName"
70
+ [returnType]="returnType"
71
+ [shouldGenerateInitCode]="!isFullViewMode && !isRunnableWithLangSelector && shouldGenerateInitCode"
72
+ [hasCodingConfigPanel]="isFullViewMode"
73
+ [autoHeight]="autoHeight"
74
+ (pasteEvent)="pasteEvent.emit($event)"
75
+ (codeChange)="parseCodeChange($event)"
76
+ >
77
+ </tgo-code-editor>
78
+ <ng-template #showSpinner>
79
+ <ui-spinner [isLoader]="false" class="code-loading-spinner"></ui-spinner>
80
+ </ng-template>
81
+ </div>
82
+ </section>
@@ -0,0 +1,64 @@
1
+ .section {
2
+ display: flex;
3
+ flex-direction: column;
4
+ height: 100%;
5
+ overflow-y: hidden;
6
+ }
7
+
8
+ .section-header {
9
+ display: flex;
10
+ justify-content: space-between;
11
+ align-items: center;
12
+ padding: 8px 16px;
13
+ border-bottom: 1px solid #E0E0E0;
14
+ max-height: 67px;
15
+
16
+ .header-controls {
17
+ display: flex;
18
+ width: 100%;
19
+ max-width: 265px;
20
+ justify-content: flex-end;
21
+ align-items: center;
22
+ flex: 1 1 auto;
23
+
24
+ .header-form {
25
+ flex: 1;
26
+ padding-right: 1em;
27
+ }
28
+
29
+ &.is-full-screen {
30
+ max-width: 305px;
31
+ }
32
+ }
33
+ }
34
+
35
+ .heading {
36
+ margin: 0;
37
+ padding: 10px 8px;
38
+ flex: 0 0 auto;
39
+ }
40
+
41
+ .ide {
42
+ flex: 1 0 auto;
43
+
44
+ @media screen and (max-width: 959px) {
45
+ flex: 1 0 350px;
46
+ }
47
+
48
+ &.spinner {
49
+ display: flex;
50
+ align-items: center;
51
+
52
+ .code-loading-spinner {
53
+ margin: 0 auto;
54
+ }
55
+ }
56
+ }
57
+
58
+ .icon {
59
+ ::ng-deep {
60
+ svg, path {
61
+ fill: var(--icon-bg-color);
62
+ }
63
+ }
64
+ }