@postgres.ai/shared 3.5.0-pr-1027 → 3.5.0-pr-1035.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (503) hide show
  1. package/components/AlertSnackbar/index.d.ts +2 -0
  2. package/components/AlertSnackbar/index.js +8 -0
  3. package/components/AlertSnackbar/useAlertSnackbar.d.ts +16 -0
  4. package/components/AlertSnackbar/useAlertSnackbar.js +37 -0
  5. package/components/Button/index.d.ts +7 -0
  6. package/components/Button/index.js +40 -0
  7. package/components/Button2/index.d.ts +13 -0
  8. package/components/Button2/index.js +10 -0
  9. package/components/DestroyCloneModal/index.d.ts +9 -0
  10. package/components/DestroyCloneModal/index.js +23 -0
  11. package/components/DestroyCloneRestrictionModal/index.d.ts +11 -0
  12. package/components/DestroyCloneRestrictionModal/index.js +16 -0
  13. package/components/ErrorStub/index.d.ts +11 -0
  14. package/components/ErrorStub/index.js +42 -0
  15. package/components/FormattedText/index.d.ts +7 -0
  16. package/components/FormattedText/index.js +23 -0
  17. package/components/GatewayLink/index.d.ts +4 -0
  18. package/components/GatewayLink/index.js +13 -0
  19. package/components/HorizontalScrollContainer/index.d.ts +13 -0
  20. package/components/HorizontalScrollContainer/index.js +72 -0
  21. package/components/HorizontalScrollContainer/types.d.ts +5 -0
  22. package/components/HorizontalScrollContainer/{types.ts → types.js} +1 -6
  23. package/components/HorizontalScrollContainer/utils.d.ts +3 -0
  24. package/components/HorizontalScrollContainer/utils.js +12 -0
  25. package/components/ImportantText/index.d.ts +6 -0
  26. package/components/ImportantText/index.js +12 -0
  27. package/components/Link2/index.d.ts +7 -0
  28. package/components/Link2/index.js +17 -0
  29. package/components/MenuButton/index.d.ts +24 -0
  30. package/components/MenuButton/index.js +16 -0
  31. package/components/Modal/index.d.ts +15 -0
  32. package/components/Modal/index.js +35 -0
  33. package/components/PageSpinner/index.d.ts +2 -0
  34. package/components/PageSpinner/{index.tsx → index.js} +5 -11
  35. package/components/ResetCloneModal/index.d.ts +13 -0
  36. package/components/ResetCloneModal/index.js +87 -0
  37. package/components/SectionTitle/index.d.ts +12 -0
  38. package/components/SectionTitle/index.js +31 -0
  39. package/components/Select/index.d.ts +18 -0
  40. package/components/Select/index.js +9 -0
  41. package/components/SimpleModalControls/index.d.ts +11 -0
  42. package/components/SimpleModalControls/index.js +19 -0
  43. package/components/Spinner/icon.d.ts +4 -0
  44. package/components/Spinner/icon.js +2 -0
  45. package/components/Spinner/index.d.ts +7 -0
  46. package/components/Spinner/index.js +8 -0
  47. package/components/Status/index.d.ts +12 -0
  48. package/components/Status/index.js +23 -0
  49. package/components/StubContainer/index.d.ts +7 -0
  50. package/components/StubContainer/index.js +14 -0
  51. package/components/StubSpinner/index.d.ts +8 -0
  52. package/components/StubSpinner/index.js +29 -0
  53. package/components/StubSpinnerFlex/index.d.ts +9 -0
  54. package/components/StubSpinnerFlex/index.js +8 -0
  55. package/components/SyntaxHighlight/index.d.ts +7 -0
  56. package/components/SyntaxHighlight/index.js +65 -0
  57. package/components/Table/RowMenu/index.d.ts +14 -0
  58. package/components/Table/RowMenu/index.js +50 -0
  59. package/components/Table/index.d.ts +12 -0
  60. package/components/Table/index.js +58 -0
  61. package/components/Text/index.d.ts +6 -0
  62. package/components/Text/index.js +11 -0
  63. package/components/TextField/index.d.ts +27 -0
  64. package/components/TextField/index.js +43 -0
  65. package/components/Tooltip/index.d.ts +12 -0
  66. package/components/Tooltip/index.js +19 -0
  67. package/config/index.d.ts +8 -0
  68. package/config/index.js +23 -0
  69. package/config/links.d.ts +6 -0
  70. package/config/links.js +6 -0
  71. package/helpers/getEntropy.d.ts +3 -0
  72. package/helpers/getEntropy.js +212 -0
  73. package/helpers/localStorage.d.ts +6 -0
  74. package/helpers/localStorage.js +13 -0
  75. package/helpers/request.d.ts +7 -0
  76. package/helpers/request.js +35 -0
  77. package/hooks/useWindowDimensions.d.ts +1 -0
  78. package/hooks/useWindowDimensions.js +12 -0
  79. package/icons/ArrowDropDown/index.d.ts +6 -0
  80. package/icons/ArrowDropDown/index.js +6 -0
  81. package/icons/Circle/index.d.ts +6 -0
  82. package/icons/Circle/index.js +5 -0
  83. package/icons/External/index.d.ts +4 -0
  84. package/icons/External/index.js +2 -0
  85. package/icons/Info/index.d.ts +4 -0
  86. package/icons/Info/index.js +2 -0
  87. package/icons/Renewable/index.d.ts +6 -0
  88. package/icons/Renewable/index.js +12 -0
  89. package/icons/Shield/index.d.ts +6 -0
  90. package/icons/Shield/index.js +12 -0
  91. package/icons/Warning/index.d.ts +6 -0
  92. package/icons/Warning/index.js +6 -0
  93. package/package.json +5 -13
  94. package/pages/Clone/Status/index.d.ts +8 -0
  95. package/pages/Clone/Status/index.js +38 -0
  96. package/pages/Clone/context.d.ts +19 -0
  97. package/pages/Clone/context.js +3 -0
  98. package/pages/Clone/index.d.ts +7 -0
  99. package/pages/Clone/index.js +221 -0
  100. package/pages/Clone/stores/Main.d.ts +45 -0
  101. package/pages/Clone/stores/Main.js +141 -0
  102. package/pages/Clone/useCreatedStores.d.ts +6 -0
  103. package/pages/Clone/useCreatedStores.js +5 -0
  104. package/pages/Configuration/Header/index.d.ts +11 -0
  105. package/pages/Configuration/Header/index.js +17 -0
  106. package/pages/Configuration/InputWithTooltip/index.d.ts +32 -0
  107. package/pages/Configuration/InputWithTooltip/index.js +60 -0
  108. package/pages/Configuration/ResponseMessage/index.d.ts +5 -0
  109. package/pages/Configuration/ResponseMessage/index.js +43 -0
  110. package/pages/Configuration/configOptions.d.ts +9 -0
  111. package/pages/Configuration/configOptions.js +59 -0
  112. package/pages/Configuration/index.d.ts +9 -0
  113. package/pages/Configuration/index.js +544 -0
  114. package/pages/Configuration/tooltipText.d.ts +20 -0
  115. package/pages/Configuration/tooltipText.js +21 -0
  116. package/pages/Configuration/useForm.d.ts +82 -0
  117. package/pages/Configuration/useForm.js +74 -0
  118. package/pages/Configuration/utils/index.d.ts +22 -0
  119. package/pages/Configuration/utils/index.js +105 -0
  120. package/pages/CreateClone/index.d.ts +17 -0
  121. package/pages/CreateClone/index.js +90 -0
  122. package/pages/CreateClone/stores/Main.d.ts +26 -0
  123. package/pages/CreateClone/stores/Main.js +61 -0
  124. package/pages/CreateClone/useCreatedStores.d.ts +6 -0
  125. package/pages/CreateClone/useCreatedStores.js +5 -0
  126. package/pages/CreateClone/useForm.d.ts +54 -0
  127. package/pages/CreateClone/useForm.js +25 -0
  128. package/pages/Instance/Clones/Header/Item/index.d.ts +7 -0
  129. package/pages/Instance/Clones/Header/Item/index.js +5 -0
  130. package/pages/Instance/Clones/Header/index.d.ts +9 -0
  131. package/pages/Instance/Clones/Header/index.js +16 -0
  132. package/pages/Instance/Clones/index.d.ts +4 -0
  133. package/pages/Instance/Clones/index.js +66 -0
  134. package/pages/Instance/ClonesModal/index.d.ts +4 -0
  135. package/pages/Instance/ClonesModal/index.js +38 -0
  136. package/pages/Instance/ClonesModal/utils.d.ts +7 -0
  137. package/pages/Instance/ClonesModal/utils.js +14 -0
  138. package/pages/Instance/InactiveInstance/index.d.ts +6 -0
  139. package/pages/Instance/InactiveInstance/index.js +65 -0
  140. package/pages/Instance/InactiveInstance/utils.d.ts +2 -0
  141. package/pages/Instance/InactiveInstance/utils.js +7 -0
  142. package/pages/Instance/Info/Connection/ConnectModal/Content/index.d.ts +4 -0
  143. package/pages/Instance/Info/Connection/ConnectModal/Content/index.js +73 -0
  144. package/pages/Instance/Info/Connection/ConnectModal/Content/utils.d.ts +3 -0
  145. package/pages/Instance/Info/Connection/ConnectModal/Content/utils.js +20 -0
  146. package/pages/Instance/Info/Connection/ConnectModal/index.d.ts +6 -0
  147. package/pages/Instance/Info/Connection/ConnectModal/index.js +17 -0
  148. package/pages/Instance/Info/Connection/index.d.ts +4 -0
  149. package/pages/Instance/Info/Connection/index.js +44 -0
  150. package/pages/Instance/Info/Details/index.d.ts +2 -0
  151. package/pages/Instance/Info/Details/index.js +6 -0
  152. package/pages/Instance/Info/Disks/Disk/ActionsMenu/index.d.ts +8 -0
  153. package/pages/Instance/Info/Disks/Disk/ActionsMenu/index.js +47 -0
  154. package/pages/Instance/Info/Disks/Disk/Marker/index.d.ts +6 -0
  155. package/pages/Instance/Info/Disks/Disk/Marker/index.js +15 -0
  156. package/pages/Instance/Info/Disks/Disk/ProgressBar/PointerIcon.d.ts +5 -0
  157. package/pages/Instance/Info/Disks/Disk/ProgressBar/PointerIcon.js +2 -0
  158. package/pages/Instance/Info/Disks/Disk/ProgressBar/index.d.ts +8 -0
  159. package/pages/Instance/Info/Disks/Disk/ProgressBar/index.js +45 -0
  160. package/pages/Instance/Info/Disks/Disk/Status/index.d.ts +6 -0
  161. package/pages/Instance/Info/Disks/Disk/Status/index.js +52 -0
  162. package/pages/Instance/Info/Disks/Disk/index.d.ts +15 -0
  163. package/pages/Instance/Info/Disks/Disk/index.js +69 -0
  164. package/pages/Instance/Info/Disks/index.d.ts +4 -0
  165. package/pages/Instance/Info/Disks/index.js +24 -0
  166. package/pages/Instance/Info/Icons/index.d.ts +7 -0
  167. package/pages/Instance/Info/Icons/index.js +3 -0
  168. package/pages/Instance/Info/Retrieval/RefreshFailedAlert/index.d.ts +4 -0
  169. package/pages/Instance/Info/Retrieval/RefreshFailedAlert/index.js +15 -0
  170. package/pages/Instance/Info/Retrieval/RetrievalModal/index.d.ts +10 -0
  171. package/pages/Instance/Info/Retrieval/RetrievalModal/index.js +15 -0
  172. package/pages/Instance/Info/Retrieval/RetrievalTable/index.d.ts +6 -0
  173. package/pages/Instance/Info/Retrieval/RetrievalTable/index.js +6 -0
  174. package/pages/Instance/Info/Retrieval/index.d.ts +4 -0
  175. package/pages/Instance/Info/Retrieval/index.js +49 -0
  176. package/pages/Instance/Info/Retrieval/utils.d.ts +2 -0
  177. package/pages/Instance/Info/Retrieval/utils.js +12 -0
  178. package/pages/Instance/Info/Snapshots/Calendar/Day/index.d.ts +11 -0
  179. package/pages/Instance/Info/Snapshots/Calendar/Day/index.js +71 -0
  180. package/pages/Instance/Info/Snapshots/Calendar/index.d.ts +8 -0
  181. package/pages/Instance/Info/Snapshots/Calendar/index.js +67 -0
  182. package/pages/Instance/Info/Snapshots/Calendar/utils.d.ts +23 -0
  183. package/pages/Instance/Info/Snapshots/Calendar/utils.js +41 -0
  184. package/pages/Instance/Info/Snapshots/TimeLine/Day/index.d.ts +6 -0
  185. package/pages/Instance/Info/Snapshots/TimeLine/Day/index.js +58 -0
  186. package/pages/Instance/Info/Snapshots/TimeLine/index.d.ts +2 -0
  187. package/pages/Instance/Info/Snapshots/TimeLine/index.js +32 -0
  188. package/pages/Instance/Info/Snapshots/index.d.ts +4 -0
  189. package/pages/Instance/Info/Snapshots/index.js +35 -0
  190. package/pages/Instance/Info/Snapshots/utils.d.ts +23 -0
  191. package/pages/Instance/Info/Snapshots/utils.js +16 -0
  192. package/pages/Instance/Info/Status/InstanceResponseModal/index.d.ts +9 -0
  193. package/pages/Instance/Info/Status/InstanceResponseModal/index.js +12 -0
  194. package/pages/Instance/Info/Status/index.d.ts +4 -0
  195. package/pages/Instance/Info/Status/index.js +31 -0
  196. package/pages/Instance/Info/Status/utils.d.ts +8 -0
  197. package/pages/Instance/Info/Status/utils.js +23 -0
  198. package/pages/Instance/Info/components/Property/index.d.ts +11 -0
  199. package/pages/Instance/Info/components/Property/index.js +14 -0
  200. package/pages/Instance/Info/components/Section/index.d.ts +8 -0
  201. package/pages/Instance/Info/components/Section/index.js +18 -0
  202. package/pages/Instance/Info/components/ValueStatus/index.d.ts +9 -0
  203. package/pages/Instance/Info/components/ValueStatus/index.js +18 -0
  204. package/pages/Instance/Info/index.d.ts +2 -0
  205. package/pages/Instance/Info/index.js +75 -0
  206. package/pages/Instance/SnapshotsModal/index.d.ts +4 -0
  207. package/pages/Instance/SnapshotsModal/index.js +81 -0
  208. package/pages/Instance/SnapshotsModal/utils.d.ts +7 -0
  209. package/{components/HorizontalScrollContainer/utils.ts → pages/Instance/SnapshotsModal/utils.js} +8 -9
  210. package/pages/Instance/Tabs/index.d.ts +9 -0
  211. package/pages/Instance/Tabs/index.js +40 -0
  212. package/pages/Instance/components/ClonesList/ConnectionModal/index.d.ts +10 -0
  213. package/pages/Instance/components/ClonesList/ConnectionModal/index.js +74 -0
  214. package/pages/Instance/components/ClonesList/MenuCell/index.d.ts +11 -0
  215. package/pages/Instance/components/ClonesList/MenuCell/index.js +49 -0
  216. package/pages/Instance/components/ClonesList/MenuCell/utils.d.ts +3 -0
  217. package/pages/Instance/components/ClonesList/MenuCell/utils.js +18 -0
  218. package/pages/Instance/components/ClonesList/index.d.ts +9 -0
  219. package/pages/Instance/components/ClonesList/index.js +52 -0
  220. package/pages/Instance/components/ErrorStub/index.d.ts +9 -0
  221. package/pages/Instance/components/ErrorStub/index.js +42 -0
  222. package/pages/Instance/components/ModalReloadButton/index.d.ts +7 -0
  223. package/pages/Instance/components/ModalReloadButton/index.js +22 -0
  224. package/pages/Instance/components/Tags/Tag/index.d.ts +7 -0
  225. package/pages/Instance/components/Tags/Tag/index.js +35 -0
  226. package/pages/Instance/components/Tags/index.d.ts +8 -0
  227. package/pages/Instance/components/Tags/index.js +16 -0
  228. package/pages/Instance/context.d.ts +31 -0
  229. package/pages/Instance/{ClonesModal/utils.ts → context.js} +5 -15
  230. package/pages/Instance/index.d.ts +8 -0
  231. package/pages/Instance/index.js +93 -0
  232. package/pages/Instance/stores/ClonesModal.d.ts +13 -0
  233. package/pages/Instance/stores/ClonesModal.js +24 -0
  234. package/pages/Instance/stores/Main.d.ts +115 -0
  235. package/pages/Instance/stores/Main.js +243 -0
  236. package/pages/Instance/stores/SnapshotsModal.d.ts +13 -0
  237. package/pages/Instance/stores/SnapshotsModal.js +24 -0
  238. package/pages/Instance/useCreatedStores.d.ts +10 -0
  239. package/pages/Instance/useCreatedStores.js +9 -0
  240. package/pages/Logs/Icons/PlusIcon.d.ts +2 -0
  241. package/pages/Logs/Icons/PlusIcon.js +2 -0
  242. package/pages/Logs/constants/index.d.ts +5 -0
  243. package/pages/Logs/constants/index.js +5 -0
  244. package/pages/Logs/hooks/useWsScroll.d.ts +1 -0
  245. package/pages/Logs/hooks/useWsScroll.js +39 -0
  246. package/pages/Logs/index.d.ts +5 -0
  247. package/pages/Logs/index.js +189 -0
  248. package/pages/Logs/utils/index.d.ts +2 -0
  249. package/pages/Logs/utils/index.js +15 -0
  250. package/pages/Logs/wsLogs.d.ts +2 -0
  251. package/pages/Logs/wsLogs.js +76 -0
  252. package/pages/Logs/wsSnackbar.d.ts +1 -0
  253. package/pages/Logs/wsSnackbar.js +25 -0
  254. package/stores/Snapshots.d.ts +15 -0
  255. package/stores/Snapshots.js +35 -0
  256. package/styles/colors.d.ts +60 -0
  257. package/styles/colors.js +66 -0
  258. package/styles/icons.d.ts +63 -0
  259. package/styles/icons.js +69 -0
  260. package/styles/styles.d.ts +1 -0
  261. package/styles/styles.js +83 -0
  262. package/styles/theme.d.ts +1 -0
  263. package/styles/theme.js +50 -0
  264. package/styles/vars.d.ts +25 -0
  265. package/styles/{vars.ts → vars.js} +20 -28
  266. package/types/api/endpoints/createClone.d.ts +12 -0
  267. package/types/api/endpoints/createClone.js +1 -0
  268. package/types/api/endpoints/destroyClone.d.ts +7 -0
  269. package/types/api/endpoints/destroyClone.js +1 -0
  270. package/types/api/endpoints/getClone.d.ts +8 -0
  271. package/types/api/endpoints/getClone.js +1 -0
  272. package/types/api/endpoints/getConfig.d.ts +5 -0
  273. package/types/api/endpoints/getConfig.js +1 -0
  274. package/types/api/endpoints/getEngine.d.ts +10 -0
  275. package/types/api/endpoints/getEngine.js +1 -0
  276. package/types/api/endpoints/getFullConfig.d.ts +4 -0
  277. package/types/api/endpoints/getFullConfig.js +1 -0
  278. package/types/api/endpoints/getInstance.d.ts +7 -0
  279. package/types/api/endpoints/getInstance.js +1 -0
  280. package/types/api/endpoints/getInstanceRetrieval.d.ts +7 -0
  281. package/types/api/endpoints/getInstanceRetrieval.js +1 -0
  282. package/types/api/endpoints/getSeImages.d.ts +19 -0
  283. package/types/api/endpoints/getSeImages.js +1 -0
  284. package/types/api/endpoints/getSnapshots.d.ts +7 -0
  285. package/types/api/endpoints/getSnapshots.js +1 -0
  286. package/types/api/endpoints/getWSToken.d.ts +7 -0
  287. package/types/api/endpoints/getWSToken.js +1 -0
  288. package/types/api/endpoints/initWS.d.ts +1 -0
  289. package/types/api/endpoints/initWS.js +1 -0
  290. package/types/api/endpoints/refreshInstance.d.ts +6 -0
  291. package/types/api/endpoints/refreshInstance.js +1 -0
  292. package/types/api/endpoints/resetClone.d.ts +8 -0
  293. package/types/api/endpoints/resetClone.js +1 -0
  294. package/types/api/endpoints/testDbSource.d.ts +22 -0
  295. package/types/api/endpoints/testDbSource.js +23 -0
  296. package/types/api/endpoints/updateClone.d.ts +10 -0
  297. package/types/api/endpoints/updateClone.js +1 -0
  298. package/types/api/endpoints/updateConfig.d.ts +5 -0
  299. package/types/api/endpoints/updateConfig.js +1 -0
  300. package/types/api/entities/clone.d.ts +50 -0
  301. package/{components/Text/index.tsx → types/api/entities/clone.js} +8 -22
  302. package/types/api/entities/config.d.ts +72 -0
  303. package/types/api/entities/config.js +35 -0
  304. package/types/api/entities/dbSource.d.ts +12 -0
  305. package/types/api/entities/dbSource.js +1 -0
  306. package/types/api/entities/instance.d.ts +109 -0
  307. package/types/api/entities/instance.js +31 -0
  308. package/types/api/entities/instanceRetrieval.d.ts +42 -0
  309. package/types/api/entities/instanceRetrieval.js +19 -0
  310. package/types/api/entities/instanceState.d.ts +109 -0
  311. package/types/api/entities/instanceState.js +42 -0
  312. package/types/api/entities/pool.d.ts +18 -0
  313. package/{utils/numbers.ts → types/api/entities/pool.js} +1 -5
  314. package/types/api/entities/snapshot.d.ts +19 -0
  315. package/types/api/entities/snapshot.js +6 -0
  316. package/types/api/entities/wsToken.d.ts +5 -0
  317. package/types/api/entities/wsToken.js +1 -0
  318. package/utils/api.d.ts +1 -0
  319. package/utils/api.js +28 -0
  320. package/utils/clone.d.ts +13 -0
  321. package/utils/clone.js +21 -0
  322. package/utils/connection.d.ts +5 -0
  323. package/utils/connection.js +28 -0
  324. package/utils/date.d.ts +16 -0
  325. package/utils/date.js +33 -0
  326. package/utils/instance.d.ts +5 -0
  327. package/utils/instance.js +11 -0
  328. package/utils/numbers.d.ts +1 -0
  329. package/utils/{strings.ts → numbers.js} +4 -5
  330. package/utils/react.d.ts +5 -0
  331. package/utils/react.js +8 -0
  332. package/utils/snapshot.d.ts +2 -0
  333. package/utils/snapshot.js +1 -0
  334. package/utils/strings.d.ts +1 -0
  335. package/utils/strings.js +10 -0
  336. package/utils/units.d.ts +5 -0
  337. package/utils/units.js +15 -0
  338. package/.gitlab-ci.yml +0 -64
  339. package/components/AlertSnackbar/index.tsx +0 -23
  340. package/components/AlertSnackbar/useAlertSnackbar.tsx +0 -65
  341. package/components/Button/index.tsx +0 -79
  342. package/components/Button2/index.tsx +0 -43
  343. package/components/DestroyCloneModal/index.tsx +0 -56
  344. package/components/DestroyCloneRestrictionModal/index.tsx +0 -50
  345. package/components/ErrorStub/index.tsx +0 -83
  346. package/components/FormattedText/index.tsx +0 -44
  347. package/components/GatewayLink/index.tsx +0 -33
  348. package/components/HorizontalScrollContainer/index.tsx +0 -131
  349. package/components/ImportantText/index.tsx +0 -29
  350. package/components/Link2/index.tsx +0 -31
  351. package/components/MenuButton/index.tsx +0 -80
  352. package/components/Modal/index.tsx +0 -93
  353. package/components/ResetCloneModal/index.tsx +0 -154
  354. package/components/SectionTitle/index.tsx +0 -74
  355. package/components/Select/index.tsx +0 -42
  356. package/components/SimpleModalControls/index.tsx +0 -56
  357. package/components/Spinner/icon.tsx +0 -29
  358. package/components/Spinner/index.tsx +0 -16
  359. package/components/Status/index.tsx +0 -61
  360. package/components/StubContainer/index.tsx +0 -41
  361. package/components/StubSpinner/index.tsx +0 -49
  362. package/components/StubSpinnerFlex/index.tsx +0 -20
  363. package/components/SyntaxHighlight/index.tsx +0 -107
  364. package/components/Table/RowMenu/index.tsx +0 -111
  365. package/components/Table/index.tsx +0 -140
  366. package/components/TextField/index.tsx +0 -117
  367. package/components/Tooltip/index.tsx +0 -52
  368. package/config/index.ts +0 -32
  369. package/config/links.ts +0 -6
  370. package/craco.config.js +0 -80
  371. package/helpers/getEntropy.ts +0 -232
  372. package/helpers/localStorage.ts +0 -15
  373. package/helpers/request.ts +0 -47
  374. package/hooks/useWindowDimensions.ts +0 -16
  375. package/icons/ArrowDropDown/index.tsx +0 -29
  376. package/icons/Circle/index.tsx +0 -27
  377. package/icons/External/index.tsx +0 -14
  378. package/icons/Info/index.tsx +0 -12
  379. package/icons/Renewable/index.tsx +0 -65
  380. package/icons/Shield/index.tsx +0 -33
  381. package/icons/Warning/index.tsx +0 -29
  382. package/pages/Clone/Status/index.tsx +0 -73
  383. package/pages/Clone/context.ts +0 -22
  384. package/pages/Clone/index.tsx +0 -634
  385. package/pages/Clone/stores/Main.ts +0 -206
  386. package/pages/Clone/useCreatedStores.ts +0 -11
  387. package/pages/Configuration/Header/index.tsx +0 -84
  388. package/pages/Configuration/InputWithTooltip/index.tsx +0 -240
  389. package/pages/Configuration/ResponseMessage/index.tsx +0 -71
  390. package/pages/Configuration/configOptions.ts +0 -60
  391. package/pages/Configuration/index.tsx +0 -1184
  392. package/pages/Configuration/tooltipText.tsx +0 -157
  393. package/pages/Configuration/useForm.ts +0 -108
  394. package/pages/Configuration/utils/index.ts +0 -153
  395. package/pages/CreateClone/index.tsx +0 -311
  396. package/pages/CreateClone/stores/Main.ts +0 -107
  397. package/pages/CreateClone/useCreatedStores.ts +0 -11
  398. package/pages/CreateClone/useForm.ts +0 -36
  399. package/pages/Instance/Clones/Header/Item/index.tsx +0 -15
  400. package/pages/Instance/Clones/Header/index.tsx +0 -74
  401. package/pages/Instance/Clones/index.tsx +0 -135
  402. package/pages/Instance/ClonesModal/index.tsx +0 -71
  403. package/pages/Instance/InactiveInstance/index.tsx +0 -165
  404. package/pages/Instance/InactiveInstance/utils.ts +0 -9
  405. package/pages/Instance/Info/Connection/ConnectModal/Content/index.tsx +0 -176
  406. package/pages/Instance/Info/Connection/ConnectModal/Content/utils.ts +0 -24
  407. package/pages/Instance/Info/Connection/ConnectModal/index.tsx +0 -36
  408. package/pages/Instance/Info/Connection/index.tsx +0 -81
  409. package/pages/Instance/Info/Details/index.tsx +0 -20
  410. package/pages/Instance/Info/Disks/Disk/ActionsMenu/index.tsx +0 -100
  411. package/pages/Instance/Info/Disks/Disk/Marker/index.tsx +0 -26
  412. package/pages/Instance/Info/Disks/Disk/ProgressBar/PointerIcon.tsx +0 -20
  413. package/pages/Instance/Info/Disks/Disk/ProgressBar/index.tsx +0 -73
  414. package/pages/Instance/Info/Disks/Disk/Status/index.tsx +0 -75
  415. package/pages/Instance/Info/Disks/Disk/index.tsx +0 -168
  416. package/pages/Instance/Info/Disks/index.tsx +0 -65
  417. package/pages/Instance/Info/Icons/index.tsx +0 -39
  418. package/pages/Instance/Info/Retrieval/RefreshFailedAlert/index.tsx +0 -32
  419. package/pages/Instance/Info/Retrieval/RetrievalModal/index.tsx +0 -49
  420. package/pages/Instance/Info/Retrieval/RetrievalTable/index.tsx +0 -53
  421. package/pages/Instance/Info/Retrieval/index.tsx +0 -95
  422. package/pages/Instance/Info/Retrieval/utils.ts +0 -10
  423. package/pages/Instance/Info/Snapshots/Calendar/Day/index.tsx +0 -125
  424. package/pages/Instance/Info/Snapshots/Calendar/index.tsx +0 -133
  425. package/pages/Instance/Info/Snapshots/Calendar/utils.ts +0 -74
  426. package/pages/Instance/Info/Snapshots/TimeLine/Day/index.tsx +0 -79
  427. package/pages/Instance/Info/Snapshots/TimeLine/index.tsx +0 -57
  428. package/pages/Instance/Info/Snapshots/index.tsx +0 -97
  429. package/pages/Instance/Info/Snapshots/utils.ts +0 -18
  430. package/pages/Instance/Info/Status/InstanceResponseModal/index.tsx +0 -32
  431. package/pages/Instance/Info/Status/index.tsx +0 -85
  432. package/pages/Instance/Info/Status/utils.ts +0 -24
  433. package/pages/Instance/Info/components/Property/index.tsx +0 -32
  434. package/pages/Instance/Info/components/Section/index.tsx +0 -50
  435. package/pages/Instance/Info/components/ValueStatus/index.tsx +0 -51
  436. package/pages/Instance/Info/index.tsx +0 -129
  437. package/pages/Instance/SnapshotsModal/index.tsx +0 -169
  438. package/pages/Instance/SnapshotsModal/utils.ts +0 -17
  439. package/pages/Instance/Tabs/index.tsx +0 -98
  440. package/pages/Instance/components/ClonesList/ConnectionModal/index.tsx +0 -196
  441. package/pages/Instance/components/ClonesList/MenuCell/index.tsx +0 -98
  442. package/pages/Instance/components/ClonesList/MenuCell/utils.ts +0 -21
  443. package/pages/Instance/components/ClonesList/index.tsx +0 -189
  444. package/pages/Instance/components/ErrorStub/index.tsx +0 -77
  445. package/pages/Instance/components/ModalReloadButton/index.tsx +0 -43
  446. package/pages/Instance/components/Tags/Tag/index.tsx +0 -60
  447. package/pages/Instance/components/Tags/index.tsx +0 -42
  448. package/pages/Instance/context.ts +0 -39
  449. package/pages/Instance/index.tsx +0 -235
  450. package/pages/Instance/stores/ClonesModal.ts +0 -35
  451. package/pages/Instance/stores/Main.ts +0 -335
  452. package/pages/Instance/stores/SnapshotsModal.ts +0 -35
  453. package/pages/Instance/useCreatedStores.ts +0 -14
  454. package/pages/Logs/Icons/PlusIcon.tsx +0 -8
  455. package/pages/Logs/constants/index.ts +0 -7
  456. package/pages/Logs/hooks/useWsScroll.tsx +0 -44
  457. package/pages/Logs/index.tsx +0 -267
  458. package/pages/Logs/utils/index.ts +0 -20
  459. package/pages/Logs/wsLogs.ts +0 -110
  460. package/pages/Logs/wsSnackbar.ts +0 -27
  461. package/postgres.ai-shared-3.5.0.tgz +0 -0
  462. package/scripts/copy-assets.js +0 -30
  463. package/scripts/pack.js +0 -70
  464. package/stores/Snapshots.ts +0 -54
  465. package/styles/colors.ts +0 -67
  466. package/styles/icons.tsx +0 -1917
  467. package/styles/styles.ts +0 -87
  468. package/styles/theme.ts +0 -53
  469. package/types/api/endpoints/createClone.ts +0 -10
  470. package/types/api/endpoints/destroyClone.ts +0 -7
  471. package/types/api/endpoints/getClone.ts +0 -6
  472. package/types/api/endpoints/getConfig.ts +0 -6
  473. package/types/api/endpoints/getEngine.ts +0 -13
  474. package/types/api/endpoints/getFullConfig.ts +0 -4
  475. package/types/api/endpoints/getInstance.ts +0 -6
  476. package/types/api/endpoints/getInstanceRetrieval.ts +0 -6
  477. package/types/api/endpoints/getSeImages.ts +0 -22
  478. package/types/api/endpoints/getSnapshots.ts +0 -6
  479. package/types/api/endpoints/getWSToken.ts +0 -6
  480. package/types/api/endpoints/initWS.ts +0 -1
  481. package/types/api/endpoints/refreshInstance.ts +0 -4
  482. package/types/api/endpoints/resetClone.ts +0 -8
  483. package/types/api/endpoints/testDbSource.ts +0 -48
  484. package/types/api/endpoints/updateClone.ts +0 -10
  485. package/types/api/endpoints/updateConfig.ts +0 -6
  486. package/types/api/entities/clone.ts +0 -42
  487. package/types/api/entities/config.ts +0 -114
  488. package/types/api/entities/dbSource.ts +0 -13
  489. package/types/api/entities/instance.ts +0 -67
  490. package/types/api/entities/instanceRetrieval.ts +0 -46
  491. package/types/api/entities/instanceState.ts +0 -102
  492. package/types/api/entities/pool.ts +0 -27
  493. package/types/api/entities/snapshot.ts +0 -18
  494. package/types/api/entities/wsToken.ts +0 -7
  495. package/types/byte-size/index.d.ts +0 -22
  496. package/utils/api.ts +0 -30
  497. package/utils/clone.ts +0 -31
  498. package/utils/connection.ts +0 -38
  499. package/utils/date.ts +0 -87
  500. package/utils/instance.ts +0 -10
  501. package/utils/react.ts +0 -10
  502. package/utils/snapshot.ts +0 -4
  503. package/utils/units.ts +0 -23
@@ -0,0 +1,11 @@
1
+ /// <reference types="react" />
2
+ import { Clone } from '@postgres.ai/shared/types/api/entities/clone';
3
+ declare type Props = {
4
+ clone: Clone;
5
+ onConnect: (cloneId: string) => void;
6
+ clonePagePath: string;
7
+ };
8
+ export declare const MenuCell: ((props: Props) => JSX.Element | null) & {
9
+ displayName: string;
10
+ };
11
+ export {};
@@ -0,0 +1,49 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ /*--------------------------------------------------------------------------
3
+ * Copyright (c) 2019-2021, Postgres.ai, Nikolay Samokhvalov nik@postgres.ai
4
+ * All Rights Reserved. Proprietary and confidential.
5
+ * Unauthorized copying of this file, via any medium is strictly prohibited
6
+ *--------------------------------------------------------------------------
7
+ */
8
+ import { useState } from 'react';
9
+ import { observer } from 'mobx-react-lite';
10
+ import { useStores } from '@postgres.ai/shared/pages/Instance/context';
11
+ import { TableBodyCellMenu } from '@postgres.ai/shared/components/Table';
12
+ import { DestroyCloneModal } from '@postgres.ai/shared/components/DestroyCloneModal';
13
+ import { DestroyCloneRestrictionModal } from '@postgres.ai/shared/components/DestroyCloneRestrictionModal';
14
+ import { ResetCloneModal } from '@postgres.ai/shared/components/ResetCloneModal';
15
+ export const MenuCell = observer((props) => {
16
+ var _a, _b;
17
+ const { clone, onConnect, clonePagePath } = props;
18
+ const stores = useStores();
19
+ const [isOpenCloneDestroyRestrictionModal, setIsOpenCloneDestroyRestrictionModal,] = useState(false);
20
+ const [isOpenCloneDestroyModal, setIsOpenCloneDestroyModal] = useState(false);
21
+ const [isOpenResetCloneModal, setIsOpenResetCloneModal] = useState(false);
22
+ const handleClickDestroyClone = () => {
23
+ if (clone.protected)
24
+ return setIsOpenCloneDestroyRestrictionModal(true);
25
+ setIsOpenCloneDestroyModal(true);
26
+ };
27
+ const handleClickResetClone = async () => {
28
+ setIsOpenResetCloneModal(true);
29
+ };
30
+ const isLoading = stores.main.unstableClones.has(clone.id);
31
+ if (!stores.main.instance)
32
+ return null;
33
+ const hasSnapshots = Boolean((_a = stores.main.snapshots.data) === null || _a === void 0 ? void 0 : _a.length);
34
+ return (_jsxs(TableBodyCellMenu, { isLoading: isLoading, isDisabled: stores.main.isDisabledInstance, actions: [
35
+ {
36
+ name: 'Connect',
37
+ onClick: () => onConnect(clone.id),
38
+ },
39
+ {
40
+ name: 'Destroy clone',
41
+ onClick: handleClickDestroyClone,
42
+ },
43
+ {
44
+ name: 'Reset clone',
45
+ onClick: handleClickResetClone,
46
+ isDisabled: !hasSnapshots,
47
+ },
48
+ ], children: [_jsx(DestroyCloneRestrictionModal, { cloneId: clone.id, isOpen: isOpenCloneDestroyRestrictionModal, onClose: () => setIsOpenCloneDestroyRestrictionModal(false), clonePagePath: clonePagePath }), _jsx(DestroyCloneModal, { cloneId: clone.id, isOpen: isOpenCloneDestroyModal, onClose: () => setIsOpenCloneDestroyModal(false), onDestroyClone: () => stores.main.destroyClone(clone.id) }), _jsx(ResetCloneModal, { clone: clone, snapshots: stores.main.snapshots.data, isOpen: isOpenResetCloneModal, onClose: () => setIsOpenResetCloneModal(false), onResetClone: (snapshotId) => stores.main.resetClone(clone.id, snapshotId), version: (_b = stores.main.instance.state) === null || _b === void 0 ? void 0 : _b.engine.version })] }));
49
+ });
@@ -0,0 +1,3 @@
1
+ export declare const destroyRestriction: (cloneId: string) => void;
2
+ export declare const getResetApprove: (cloneId: string) => boolean;
3
+ export declare const getDestroyApprove: (cloneId: string) => boolean;
@@ -0,0 +1,18 @@
1
+ /*--------------------------------------------------------------------------
2
+ * Copyright (c) 2019-2021, Postgres.ai, Nikolay Samokhvalov nik@postgres.ai
3
+ * All Rights Reserved. Proprietary and confidential.
4
+ * Unauthorized copying of this file, via any medium is strictly prohibited
5
+ *--------------------------------------------------------------------------
6
+ */
7
+ export const destroyRestriction = (cloneId) => {
8
+ const message = `The clone "${cloneId}" is marked as protected. To destroy it, disable the destroy protection first.`;
9
+ window.alert(message);
10
+ };
11
+ export const getResetApprove = (cloneId) => {
12
+ const message = `Are you sure you want to reset the Database Lab clone: "${cloneId}"?`;
13
+ return window.confirm(message);
14
+ };
15
+ export const getDestroyApprove = (cloneId) => {
16
+ const message = `Are you sure you want to destroy the Database Lab clone: "${cloneId}"?`;
17
+ return window.confirm(message);
18
+ };
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ import { Clone } from '@postgres.ai/shared/types/api/entities/clone';
3
+ declare type Props = {
4
+ clones?: Clone[];
5
+ isDisabled: boolean;
6
+ emptyStubText: string;
7
+ };
8
+ export declare const ClonesList: (props: Props) => JSX.Element;
9
+ export {};
@@ -0,0 +1,52 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ /*--------------------------------------------------------------------------
3
+ * Copyright (c) 2019-2021, Postgres.ai, Nikolay Samokhvalov nik@postgres.ai
4
+ * All Rights Reserved. Proprietary and confidential.
5
+ * Unauthorized copying of this file, via any medium is strictly prohibited
6
+ *--------------------------------------------------------------------------
7
+ */
8
+ import { useState } from 'react';
9
+ import cn from 'classnames';
10
+ import { formatDistanceToNowStrict } from 'date-fns';
11
+ import { useHistory } from 'react-router-dom';
12
+ import { Table, TableHead, TableRow, TableHeaderCell, TableBody, TableBodyCell, } from '@postgres.ai/shared/components/Table';
13
+ import { ArrowDropDownIcon } from '@postgres.ai/shared/icons/ArrowDropDown';
14
+ import { ShieldIcon } from '@postgres.ai/shared/icons/Shield';
15
+ import { RenewableIcon } from '@postgres.ai/shared/icons/Renewable';
16
+ import { InfoIcon } from '@postgres.ai/shared/icons/Info';
17
+ import { HorizontalScrollContainer } from '@postgres.ai/shared/components/HorizontalScrollContainer';
18
+ import { Status } from '@postgres.ai/shared/components/Status';
19
+ import { Tooltip } from '@postgres.ai/shared/components/Tooltip';
20
+ import { useHost } from '@postgres.ai/shared/pages/Instance/context';
21
+ import { getCloneStatusType, getCloneStatusText, } from '@postgres.ai/shared/utils/clone';
22
+ import { formatBytesIEC } from '@postgres.ai/shared/utils/units';
23
+ import { MenuCell } from './MenuCell';
24
+ import { ConnectionModal } from './ConnectionModal';
25
+ import styles from './styles.module.scss';
26
+ export const ClonesList = (props) => {
27
+ var _a;
28
+ const host = useHost();
29
+ const history = useHistory();
30
+ const [cloneIdForConnect, setCloneIdForConnect] = useState(null);
31
+ const [isOpenConnectionModal, setIsOpenConnectionModal] = useState(false);
32
+ const openConnectionModal = (cloneId) => {
33
+ setCloneIdForConnect(cloneId);
34
+ setIsOpenConnectionModal(true);
35
+ };
36
+ const closeConnectionModal = () => {
37
+ setIsOpenConnectionModal(false);
38
+ };
39
+ if (!((_a = props.clones) === null || _a === void 0 ? void 0 : _a.length))
40
+ return _jsx("p", { className: styles.emptyStub, children: props.emptyStubText });
41
+ return (_jsxs(_Fragment, { children: [_jsx(HorizontalScrollContainer, { children: _jsxs(Table, { children: [_jsx(TableHead, { children: _jsxs(TableRow, { children: [_jsx(TableHeaderCell, {}), _jsx(TableHeaderCell, { children: "Status" }), _jsx(TableHeaderCell, { children: "ID" }), _jsx(TableHeaderCell, { children: _jsx(Tooltip, { content: "When enabled, neither manual nor automated deletion of this clone is possible. Note that abandoned protected clones may lead to out-of-disk-space events because they hold old data, blocking cleanup and refresh processes.", children: _jsxs("div", { className: styles.verticalCentered, children: ["Protected", _jsx(InfoIcon, { className: styles.infoIcon })] }) }) }), _jsx(TableHeaderCell, { children: _jsxs("div", { className: styles.verticalCentered, children: ["Created", _jsx(ArrowDropDownIcon, { className: styles.sortIcon })] }) }), _jsx(TableHeaderCell, { children: "Port" }), _jsx(TableHeaderCell, { children: "DB user" }), _jsx(TableHeaderCell, { children: _jsx(Tooltip, { content: "Clone's own size \u2013 how much data was added or modified.", children: _jsxs("div", { className: styles.verticalCentered, children: ["Diff size", _jsx(InfoIcon, { className: styles.infoIcon })] }) }) }), _jsx(TableHeaderCell, { children: "Disk" }), _jsx(TableHeaderCell, { children: "Data state time" })] }) }), _jsx(TableBody, { children: props.clones.map((clone) => {
42
+ var _a, _b;
43
+ const clonePagePath = host.routes.clone(clone.id);
44
+ return (_jsxs(TableRow, { hover: !props.isDisabled, onClick: props.isDisabled
45
+ ? undefined
46
+ : () => history.push(clonePagePath), className: cn(!props.isDisabled && styles.interactiveRow), children: [_jsx(MenuCell, { clone: clone, onConnect: openConnectionModal, clonePagePath: clonePagePath }), _jsx(TableBodyCell, { children: _jsx(Tooltip, { content: clone.status.message, children: _jsx(Status, { type: getCloneStatusType(clone.status.code), children: getCloneStatusText(clone.status.code) }) }) }), _jsx(TableBodyCell, { children: clone.id }), _jsx(TableBodyCell, { children: clone.protected ? (_jsx(Tooltip, { content: "Clone is protected from manual and automated deletion. Note that abandoned protected clones may lead to out-of-disk-space events because they hold old data, blocking cleanup and refresh processes.", children: _jsx(ShieldIcon, { className: styles.protectionIcon }) })) : (_jsx(Tooltip, { content: "Clone is not protected from deletion. To save disk space it will be automatically deleted if there is no activity for a long time.", children: _jsx(RenewableIcon, { className: styles.protectionIcon }) })) }), _jsxs(TableBodyCell, { children: [clone.createdAt, " (", formatDistanceToNowStrict(clone.createdAtDate, {
47
+ addSuffix: true,
48
+ }), ")"] }), _jsx(TableBodyCell, { children: clone.db.port }), _jsx(TableBodyCell, { children: clone.db.username }), _jsx(TableBodyCell, { children: formatBytesIEC(clone.metadata.cloneDiffSize) }), _jsx(TableBodyCell, { children: (_b = (_a = clone.snapshot) === null || _a === void 0 ? void 0 : _a.pool) !== null && _b !== void 0 ? _b : '-' }), _jsx(TableBodyCell, { children: clone.snapshot ? (_jsxs(_Fragment, { children: [clone.snapshot.dataStateAt, " (", formatDistanceToNowStrict(clone.snapshot.dataStateAtDate, {
49
+ addSuffix: true,
50
+ }), ")"] })) : ('-') })] }, clone.id));
51
+ }) })] }) }), cloneIdForConnect && (_jsx(ConnectionModal, { cloneId: cloneIdForConnect, isOpen: isOpenConnectionModal, onClose: closeConnectionModal }))] }));
52
+ };
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ declare type Props = {
3
+ title?: string;
4
+ message: string;
5
+ className?: string;
6
+ size?: 'big' | 'normal';
7
+ };
8
+ export declare const ErrorStub: (props: Props) => JSX.Element;
9
+ export {};
@@ -0,0 +1,42 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Paper, makeStyles } from '@material-ui/core';
3
+ import clsx from 'clsx';
4
+ const useStyles = makeStyles({
5
+ '*': {
6
+ margin: 0,
7
+ },
8
+ root: {
9
+ color: '#c00111',
10
+ overflowWrap: 'break-word',
11
+ },
12
+ rootBig: {
13
+ padding: '16px 24px',
14
+ '& $title': {
15
+ fontSize: '16px',
16
+ },
17
+ '& $message': {
18
+ marginTop: '16px',
19
+ fontSize: '14px',
20
+ },
21
+ },
22
+ rootNormal: {
23
+ padding: '8px 16px',
24
+ '& $title': {
25
+ fontSize: '14px',
26
+ },
27
+ '& $message': {
28
+ marginTop: '12px',
29
+ fontSize: '12px',
30
+ },
31
+ },
32
+ title: {
33
+ fontWeight: 700,
34
+ textTransform: 'uppercase',
35
+ },
36
+ message: {},
37
+ }, { index: 1 });
38
+ export const ErrorStub = (props) => {
39
+ const { title = 'Unknown error', message, className, size = 'big' } = props;
40
+ const classes = useStyles();
41
+ return (_jsxs(Paper, { className: clsx(classes.root, size === 'big' && classes.rootBig, size === 'normal' && classes.rootNormal, className), children: [_jsx("h2", { className: classes.title, children: title }), _jsx("p", { className: classes.message, children: message })] }));
42
+ };
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ declare type Props = {
3
+ isReloading: boolean;
4
+ onReload: () => void;
5
+ };
6
+ export declare const ModalReloadButton: (props: Props) => JSX.Element;
7
+ export {};
@@ -0,0 +1,22 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ /*--------------------------------------------------------------------------
3
+ * Copyright (c) 2019-2021, Postgres.ai, Nikolay Samokhvalov nik@postgres.ai
4
+ * All Rights Reserved. Proprietary and confidential.
5
+ * Unauthorized copying of this file, via any medium is strictly prohibited
6
+ *--------------------------------------------------------------------------
7
+ */
8
+ import { makeStyles } from '@material-ui/core';
9
+ import { Button } from '@postgres.ai/shared/components/Button2';
10
+ const useStyles = makeStyles({
11
+ spinner: {
12
+ margin: '5px',
13
+ },
14
+ content: {
15
+ flex: '0 0 auto',
16
+ alignSelf: 'flex-start',
17
+ },
18
+ }, { index: 1 });
19
+ export const ModalReloadButton = (props) => {
20
+ const classes = useStyles();
21
+ return (_jsx(Button, { onClick: props.onReload, className: classes.content, isLoading: props.isReloading, isDisabled: props.isReloading, children: "Reload info" }));
22
+ };
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ declare type Props = {
3
+ name: string;
4
+ children: React.ReactNode;
5
+ };
6
+ export declare const Tag: (props: Props) => JSX.Element;
7
+ export {};
@@ -0,0 +1,35 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { makeStyles } from '@material-ui/core';
3
+ import { HorizontalScrollContainer } from '@postgres.ai/shared/components/HorizontalScrollContainer';
4
+ import { colors } from '@postgres.ai/shared/styles/vars';
5
+ const useStyles = makeStyles({
6
+ root: {
7
+ fontSize: '12px',
8
+ marginRight: '8px',
9
+ marginBottom: '8px',
10
+ borderRadius: '12px',
11
+ background: colors.gray,
12
+ },
13
+ content: {
14
+ padding: '5px 8px',
15
+ whiteSpace: 'nowrap',
16
+ },
17
+ curtainLeft: {
18
+ background: 'linear-gradient(to right, rgba(0,0,0,0.1), transparent);',
19
+ },
20
+ curtainRight: {
21
+ background: 'linear-gradient(to left, rgba(0,0,0,0.1), transparent);',
22
+ },
23
+ value: {
24
+ fontWeight: 700,
25
+ },
26
+ }, { index: 1 });
27
+ export const Tag = (props) => {
28
+ const classes = useStyles();
29
+ return (_jsxs(HorizontalScrollContainer, { classes: {
30
+ root: classes.root,
31
+ content: classes.content,
32
+ curtainLeft: classes.curtainLeft,
33
+ curtainRight: classes.curtainRight,
34
+ }, children: [props.name, ": ", _jsx("span", { className: classes.value, children: props.children })] }));
35
+ };
@@ -0,0 +1,8 @@
1
+ /// <reference types="react" />
2
+ export declare type TagsProps = {
3
+ data: {
4
+ name: string;
5
+ value: string;
6
+ }[];
7
+ };
8
+ export declare const Tags: (props: TagsProps) => JSX.Element;
@@ -0,0 +1,16 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { makeStyles } from '@material-ui/core';
3
+ import { Tag } from './Tag';
4
+ const useStyles = makeStyles({
5
+ root: {
6
+ display: 'flex',
7
+ flexWrap: 'wrap',
8
+ marginRight: '-8px',
9
+ },
10
+ }, { index: 1 });
11
+ export const Tags = (props) => {
12
+ const classes = useStyles();
13
+ return (_jsx("div", { className: classes.root, children: props.data.map((tag) => {
14
+ return (_jsx(Tag, { name: tag.name, children: tag.value }, tag.name));
15
+ }) }));
16
+ };
@@ -0,0 +1,31 @@
1
+ /// <reference types="react" />
2
+ import { Api } from './stores/Main';
3
+ export declare type Host = {
4
+ instanceId: string;
5
+ routes: {
6
+ createClone: () => string;
7
+ clone: (cloneId: string) => string;
8
+ };
9
+ api: Api;
10
+ title: string;
11
+ callbacks?: {
12
+ showDeprecatedApiBanner: () => void;
13
+ hideDeprecatedApiBanner: () => void;
14
+ };
15
+ elements: {
16
+ breadcrumbs: React.ReactNode;
17
+ };
18
+ wsHost?: string;
19
+ isPlatform?: boolean;
20
+ setProjectAlias?: (alias: string) => void;
21
+ };
22
+ export declare const useHost: () => Host, HostProvider: import("react").Provider<Host>;
23
+ export declare const useStores: () => {
24
+ main: import("./stores/Main").MainStore;
25
+ clonesModal: import("./stores/ClonesModal").ClonesModalStore;
26
+ snapshotsModal: import("./stores/SnapshotsModal").SnapshotsModalStore;
27
+ }, StoresProvider: import("react").Provider<{
28
+ main: import("./stores/Main").MainStore;
29
+ clonesModal: import("./stores/ClonesModal").ClonesModalStore;
30
+ snapshotsModal: import("./stores/SnapshotsModal").SnapshotsModalStore;
31
+ }>;
@@ -4,18 +4,8 @@
4
4
  * Unauthorized copying of this file, via any medium is strictly prohibited
5
5
  *--------------------------------------------------------------------------
6
6
  */
7
-
8
- export const getTags = ({
9
- pool,
10
- snapshotId,
11
- }: {
12
- pool: string | null
13
- snapshotId: string | null
14
- }) => {
15
- const tags = []
16
-
17
- if (pool) tags.push({ name: 'Disk', value: pool })
18
- if (snapshotId) tags.push({ name: 'Snapshot', value: snapshotId })
19
-
20
- return tags
21
- }
7
+ import { createStrictContext } from '@postgres.ai/shared/utils/react';
8
+ // Host context.
9
+ export const { useStrictContext: useHost, Provider: HostProvider } = createStrictContext();
10
+ // Stores context.
11
+ export const { useStrictContext: useStores, Provider: StoresProvider } = createStrictContext();
@@ -0,0 +1,8 @@
1
+ /// <reference types="react" />
2
+ import { Host } from './context';
3
+ import './styles.scss';
4
+ declare type Props = Host;
5
+ export declare const Instance: ((props: Props) => JSX.Element) & {
6
+ displayName: string;
7
+ };
8
+ export {};
@@ -0,0 +1,93 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ /*--------------------------------------------------------------------------
3
+ * Copyright (c) 2019-2021, Postgres.ai, Nikolay Samokhvalov nik@postgres.ai
4
+ * All Rights Reserved. Proprietary and confidential.
5
+ * Unauthorized copying of this file, via any medium is strictly prohibited
6
+ *--------------------------------------------------------------------------
7
+ */
8
+ import React, { useEffect } from 'react';
9
+ import { makeStyles } from '@material-ui/core';
10
+ import { observer } from 'mobx-react-lite';
11
+ import { Button } from '@postgres.ai/shared/components/Button2';
12
+ import { StubSpinner } from '@postgres.ai/shared/components/StubSpinner';
13
+ import { SectionTitle } from '@postgres.ai/shared/components/SectionTitle';
14
+ import { ErrorStub } from '@postgres.ai/shared/components/ErrorStub';
15
+ import { Tabs } from './Tabs';
16
+ import { Logs } from '../Logs';
17
+ import { Clones } from './Clones';
18
+ import { Info } from './Info';
19
+ import { Configuration } from '../Configuration';
20
+ import { ClonesModal } from './ClonesModal';
21
+ import { SnapshotsModal } from './SnapshotsModal';
22
+ import { InactiveInstance } from './InactiveInstance';
23
+ import { HostProvider, StoresProvider } from './context';
24
+ import Typography from '@material-ui/core/Typography';
25
+ import Box from '@mui/material/Box';
26
+ import { useCreatedStores } from './useCreatedStores';
27
+ import './styles.scss';
28
+ const useStyles = makeStyles((theme) => ({
29
+ title: {
30
+ marginTop: '8px',
31
+ },
32
+ reloadButton: {
33
+ flex: '0 0 auto',
34
+ alignSelf: 'flex-start',
35
+ },
36
+ errorStub: {
37
+ marginTop: '16px',
38
+ },
39
+ content: {
40
+ display: 'flex',
41
+ marginTop: '16px',
42
+ position: 'relative',
43
+ flex: '1 1 100%',
44
+ height: '100%',
45
+ [theme.breakpoints.down('sm')]: {
46
+ flexDirection: 'column',
47
+ },
48
+ },
49
+ }), { index: 1 });
50
+ export const Instance = observer((props) => {
51
+ var _a, _b, _c, _d;
52
+ const classes = useStyles();
53
+ const { instanceId, api } = props;
54
+ const [activeTab, setActiveTab] = React.useState(0);
55
+ const [hasBeenRedirected, setHasBeenRedirected] = React.useState(false);
56
+ const stores = useCreatedStores(props);
57
+ const { instance, instanceError, instanceRetrieval, isLoadingInstance, load, reload, } = stores.main;
58
+ const switchTab = (_, tabID) => {
59
+ const contentElement = document.getElementById('content-container');
60
+ setActiveTab(tabID);
61
+ if (tabID === 0) {
62
+ load(props.instanceId);
63
+ }
64
+ contentElement === null || contentElement === void 0 ? void 0 : contentElement.scroll(0, 0);
65
+ };
66
+ const isInstanceIntegrated = instanceRetrieval ||
67
+ (!isLoadingInstance && instance && (instance === null || instance === void 0 ? void 0 : instance.url) && !instanceError);
68
+ const isConfigurationActive = (instanceRetrieval === null || instanceRetrieval === void 0 ? void 0 : instanceRetrieval.mode) !== 'physical';
69
+ useEffect(() => {
70
+ load(instanceId);
71
+ }, [instanceId]);
72
+ useEffect(() => {
73
+ if (props.setProjectAlias)
74
+ props.setProjectAlias((instance === null || instance === void 0 ? void 0 : instance.projectAlias) || '');
75
+ }, [instance]);
76
+ useEffect(() => {
77
+ var _a, _b;
78
+ if (instance &&
79
+ ((_b = (_a = instance === null || instance === void 0 ? void 0 : instance.state) === null || _a === void 0 ? void 0 : _a.retrieving) === null || _b === void 0 ? void 0 : _b.status) === 'pending' &&
80
+ isConfigurationActive &&
81
+ !props.isPlatform &&
82
+ !hasBeenRedirected) {
83
+ setActiveTab(2);
84
+ setHasBeenRedirected(true);
85
+ }
86
+ }, [instance, hasBeenRedirected]);
87
+ return (_jsx(HostProvider, { value: props, children: _jsxs(StoresProvider, { value: stores, children: [props.elements.breadcrumbs, _jsx(SectionTitle, { text: props.title, level: 1, tag: "h1", className: classes.title, rightContent: _jsx(Button, { onClick: () => reload(props.instanceId), isDisabled: !instance && !instanceError, className: classes.reloadButton, children: "Reload info" }), children: isInstanceIntegrated && (_jsx(Tabs, { isPlatform: props.isPlatform, value: activeTab, handleChange: switchTab, hasLogs: api.initWS != undefined })) }), instanceError && (_jsx(ErrorStub, { ...instanceError, className: classes.errorStub })), isInstanceIntegrated ? (_jsxs(_Fragment, { children: [_jsxs(TabPanel, { value: activeTab, index: 0, children: [!instanceError && (_jsxs("div", { className: classes.content, children: [!instance ||
88
+ (!((_b = (_a = instance === null || instance === void 0 ? void 0 : instance.state) === null || _a === void 0 ? void 0 : _a.retrieving) === null || _b === void 0 ? void 0 : _b.status) && _jsx(StubSpinner, {})), instance ? (_jsxs(_Fragment, { children: [_jsx(Clones, {}), _jsx(Info, {})] })) : (_jsx(StubSpinner, {}))] })), _jsx(ClonesModal, {}), _jsx(SnapshotsModal, {})] }), !props.isPlatform && (_jsxs(_Fragment, { children: [_jsx(TabPanel, { value: activeTab, index: 1, children: activeTab === 1 && _jsx(Logs, { api: api }) }), _jsx(TabPanel, { value: activeTab, index: 2, children: _jsx(Configuration, { isConfigurationActive: isConfigurationActive, disableConfigModification: (_c = instance === null || instance === void 0 ? void 0 : instance.state) === null || _c === void 0 ? void 0 : _c.engine.disableConfigModification, switchActiveTab: switchTab, reload: () => load(props.instanceId) }) })] }))] })) : !isLoadingInstance && !instanceError ? (_jsx(TabPanel, { value: activeTab, index: activeTab, children: _jsx(InactiveInstance, { instance: instance, org: (_d = props.elements.breadcrumbs) === null || _d === void 0 ? void 0 : _d.props.org }) })) : (!instanceError && (_jsx(TabPanel, { value: activeTab, index: 0, children: _jsx("div", { className: classes.content, children: _jsx(StubSpinner, {}) }) })))] }) }));
89
+ });
90
+ function TabPanel(props) {
91
+ const { children, value, index, ...other } = props;
92
+ return (_jsx(Typography, { component: "div", role: "tabpanel", hidden: value !== index, id: `scrollable-auto-tabpanel-${index}`, "aria-labelledby": `scrollable-auto-tab-${index}`, ...other, children: _jsx(Box, { p: 3, sx: { height: '100%' }, children: children }) }));
93
+ }
@@ -0,0 +1,13 @@
1
+ declare type FilterOptions = {
2
+ pool?: string | null;
3
+ snapshotId?: string;
4
+ };
5
+ export declare class ClonesModalStore {
6
+ isOpenModal: boolean;
7
+ pool: string | null;
8
+ snapshotId: string | null;
9
+ constructor();
10
+ openModal: (filterOptions?: FilterOptions | undefined) => void;
11
+ closeModal: () => void;
12
+ }
13
+ export {};
@@ -0,0 +1,24 @@
1
+ /*--------------------------------------------------------------------------
2
+ * Copyright (c) 2019-2021, Postgres.ai, Nikolay Samokhvalov nik@postgres.ai
3
+ * All Rights Reserved. Proprietary and confidential.
4
+ * Unauthorized copying of this file, via any medium is strictly prohibited
5
+ *--------------------------------------------------------------------------
6
+ */
7
+ import { makeAutoObservable } from 'mobx';
8
+ export class ClonesModalStore {
9
+ constructor() {
10
+ this.isOpenModal = false;
11
+ this.pool = null;
12
+ this.snapshotId = null;
13
+ this.openModal = (filterOptions = {}) => {
14
+ const { pool = null, snapshotId = null } = filterOptions;
15
+ this.pool = pool;
16
+ this.snapshotId = snapshotId;
17
+ this.isOpenModal = true;
18
+ };
19
+ this.closeModal = () => {
20
+ this.isOpenModal = false;
21
+ };
22
+ makeAutoObservable(this);
23
+ }
24
+ }
@@ -0,0 +1,115 @@
1
+ import { GetSnapshots } from '@postgres.ai/shared/types/api/endpoints/getSnapshots';
2
+ import { GetInstance } from '@postgres.ai/shared/types/api/endpoints/getInstance';
3
+ import { Config } from '@postgres.ai/shared/types/api/entities/config';
4
+ import { GetConfig } from '@postgres.ai/shared/types/api/endpoints/getConfig';
5
+ import { UpdateConfig } from '@postgres.ai/shared/types/api/endpoints/updateConfig';
6
+ import { TestDbSource } from '@postgres.ai/shared/types/api/endpoints/testDbSource';
7
+ import { RefreshInstance } from '@postgres.ai/shared/types/api/endpoints/refreshInstance';
8
+ import { DestroyClone } from '@postgres.ai/shared/types/api/endpoints/destroyClone';
9
+ import { ResetClone } from '@postgres.ai/shared/types/api/endpoints/resetClone';
10
+ import { GetWSToken } from '@postgres.ai/shared/types/api/endpoints/getWSToken';
11
+ import { InitWS } from '@postgres.ai/shared/types/api/endpoints/initWS';
12
+ import { Instance } from '@postgres.ai/shared/types/api/entities/instance';
13
+ import { SnapshotsStore } from '@postgres.ai/shared/stores/Snapshots';
14
+ import { dbSource } from '@postgres.ai/shared/types/api/entities/dbSource';
15
+ import { GetFullConfig } from '@postgres.ai/shared/types/api/endpoints/getFullConfig';
16
+ import { GetInstanceRetrieval } from '@postgres.ai/shared/types/api/endpoints/getInstanceRetrieval';
17
+ import { InstanceRetrievalType } from '@postgres.ai/shared/types/api/entities/instanceRetrieval';
18
+ import { GetEngine } from '@postgres.ai/shared/types/api/endpoints/getEngine';
19
+ import { GetSeImages } from '@postgres.ai/shared/types/api/endpoints/getSeImages';
20
+ export declare type Api = {
21
+ getInstance: GetInstance;
22
+ getSnapshots: GetSnapshots;
23
+ refreshInstance?: RefreshInstance;
24
+ destroyClone: DestroyClone;
25
+ resetClone: ResetClone;
26
+ getWSToken: GetWSToken;
27
+ initWS?: InitWS;
28
+ getConfig?: GetConfig;
29
+ updateConfig?: UpdateConfig;
30
+ testDbSource?: TestDbSource;
31
+ getFullConfig?: GetFullConfig;
32
+ getSeImages?: GetSeImages;
33
+ getEngine?: GetEngine;
34
+ getInstanceRetrieval?: GetInstanceRetrieval;
35
+ };
36
+ declare type Error = {
37
+ title?: string;
38
+ message?: string;
39
+ };
40
+ export declare class MainStore {
41
+ instance: Instance | null;
42
+ instanceRetrieval: InstanceRetrievalType | null;
43
+ config: Config | null;
44
+ fullConfig?: string;
45
+ platformUrl?: string;
46
+ instanceError: Error | null;
47
+ configError: string | null;
48
+ getFullConfigError: string | null;
49
+ seImagesError: string | undefined | null;
50
+ unstableClones: Set<string>;
51
+ readonly snapshots: SnapshotsStore;
52
+ isReloadingClones: boolean;
53
+ isConfigurationLoading: boolean;
54
+ isReloadingInstance: boolean;
55
+ isReloadingInstanceRetrieval: boolean;
56
+ isLoadingInstance: boolean;
57
+ private readonly api;
58
+ constructor(api: Api);
59
+ get isDisabledInstance(): boolean;
60
+ load: (instanceId: string) => void;
61
+ reload: (instanceId: string) => void;
62
+ reloadSnapshots: () => Promise<void>;
63
+ reloadInstanceRetrieval: () => Promise<void>;
64
+ private loadInstanceRetrieval;
65
+ private loadInstance;
66
+ getConfig: () => Promise<{
67
+ dockerPath: string | undefined;
68
+ tuningParams: string;
69
+ sharedBuffers: string | undefined;
70
+ sharedPreloadLibraries: string | undefined;
71
+ timetable: string | undefined;
72
+ dbname: string | undefined;
73
+ host: string | undefined;
74
+ port: string | number | undefined;
75
+ username: string | undefined;
76
+ password: string | undefined;
77
+ databases: string;
78
+ dumpParallelJobs: string | number | undefined;
79
+ dumpIgnoreErrors: boolean | undefined;
80
+ restoreParallelJobs: string | number | undefined;
81
+ restoreIgnoreErrors: boolean | undefined;
82
+ pgDumpCustomOptions: string;
83
+ pgRestoreCustomOptions: string;
84
+ dockerTag?: string | undefined;
85
+ dockerImageType?: string | undefined;
86
+ debug: boolean | undefined;
87
+ dockerImage: string | undefined;
88
+ } | null | undefined>;
89
+ updateConfig: (values: Config) => Promise<Response | null | undefined>;
90
+ getFullConfig: () => Promise<string | null | undefined>;
91
+ getSeImages: (values: {
92
+ packageGroup: string;
93
+ }) => Promise<import("@postgres.ai/shared/types/api/endpoints/getSeImages").SeImages[] | null | undefined>;
94
+ getEngine: () => Promise<import("@postgres.ai/shared/types/api/endpoints/getEngine").EngineDto | null | undefined>;
95
+ testDbSource: (values: dbSource) => Promise<{
96
+ response: {
97
+ status: number;
98
+ message: string;
99
+ result: string;
100
+ dbVersion: number;
101
+ tuningParams: {
102
+ [key: string]: string;
103
+ };
104
+ } | null;
105
+ error: {
106
+ status: number;
107
+ message: string;
108
+ };
109
+ } | undefined>;
110
+ resetClone: (cloneId: string, snapshotId: string) => Promise<boolean | undefined>;
111
+ destroyClone: (cloneId: string) => Promise<boolean | undefined>;
112
+ private liveUpdateInstance;
113
+ reloadClones: () => Promise<void>;
114
+ }
115
+ export {};