@postgres.ai/shared 3.5.1-pr-1027.0 → 4.0.0-pr-1028

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 (596) 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 +26 -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 +89 -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 +7 -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/PostgresSQL/index.d.ts +2 -0
  88. package/icons/PostgresSQL/index.js +40 -0
  89. package/icons/Renewable/index.d.ts +6 -0
  90. package/icons/Renewable/index.js +12 -0
  91. package/icons/Shield/index.d.ts +6 -0
  92. package/icons/Shield/index.js +12 -0
  93. package/icons/Warning/index.d.ts +6 -0
  94. package/icons/Warning/index.js +6 -0
  95. package/package.json +5 -13
  96. package/pages/Branches/Branch/context.d.ts +22 -0
  97. package/pages/Branches/Branch/context.js +3 -0
  98. package/pages/Branches/Branch/index.d.ts +9 -0
  99. package/pages/Branches/Branch/index.js +172 -0
  100. package/pages/Branches/Branch/stores/Main.d.ts +37 -0
  101. package/pages/Branches/Branch/stores/Main.js +90 -0
  102. package/pages/Branches/Branch/useCreatedStores.d.ts +6 -0
  103. package/pages/Branches/Branch/useCreatedStores.js +5 -0
  104. package/pages/Branches/components/BranchesTable/index.d.ts +10 -0
  105. package/pages/Branches/components/BranchesTable/index.js +107 -0
  106. package/pages/Branches/components/Modals/DeleteBranchModal/index.d.ts +11 -0
  107. package/pages/Branches/components/Modals/DeleteBranchModal/index.js +49 -0
  108. package/pages/Branches/components/Modals/types.d.ts +4 -0
  109. package/pages/Branches/components/Modals/types.js +1 -0
  110. package/pages/Branches/index.d.ts +6 -0
  111. package/pages/Branches/index.js +60 -0
  112. package/pages/Clone/Status/index.d.ts +8 -0
  113. package/pages/Clone/Status/index.js +38 -0
  114. package/pages/Clone/context.d.ts +21 -0
  115. package/pages/Clone/context.js +3 -0
  116. package/pages/Clone/index.d.ts +9 -0
  117. package/pages/Clone/index.js +252 -0
  118. package/pages/Clone/stores/Main.d.ts +47 -0
  119. package/pages/Clone/stores/Main.js +141 -0
  120. package/pages/Clone/useCreatedStores.d.ts +6 -0
  121. package/pages/Clone/useCreatedStores.js +5 -0
  122. package/pages/Clone/utils/index.d.ts +4 -0
  123. package/pages/Clone/utils/index.js +12 -0
  124. package/pages/CreateBranch/index.d.ts +17 -0
  125. package/pages/CreateBranch/index.js +135 -0
  126. package/pages/CreateBranch/stores/Main.d.ts +43 -0
  127. package/pages/CreateBranch/stores/Main.js +59 -0
  128. package/pages/CreateBranch/useCreatedStores.d.ts +6 -0
  129. package/pages/CreateBranch/useCreatedStores.js +5 -0
  130. package/pages/CreateBranch/useForm.d.ts +51 -0
  131. package/pages/CreateBranch/useForm.js +30 -0
  132. package/pages/CreateBranch/utils/index.d.ts +2 -0
  133. package/pages/CreateBranch/utils/index.js +10 -0
  134. package/pages/CreateClone/index.d.ts +19 -0
  135. package/pages/CreateClone/index.js +142 -0
  136. package/pages/CreateClone/stores/Main.d.ts +49 -0
  137. package/pages/CreateClone/stores/Main.js +85 -0
  138. package/pages/CreateClone/styles.module.scss +47 -4
  139. package/pages/CreateClone/useCreatedStores.d.ts +6 -0
  140. package/pages/CreateClone/useCreatedStores.js +5 -0
  141. package/pages/CreateClone/useForm.d.ts +55 -0
  142. package/pages/CreateClone/useForm.js +26 -0
  143. package/pages/CreateClone/utils/index.d.ts +3 -0
  144. package/pages/CreateClone/utils/index.js +17 -0
  145. package/pages/CreateSnapshot/index.d.ts +17 -0
  146. package/pages/CreateSnapshot/index.js +117 -0
  147. package/pages/CreateSnapshot/stores/Main.d.ts +21 -0
  148. package/pages/CreateSnapshot/stores/Main.js +31 -0
  149. package/pages/CreateSnapshot/useCreatedStores.d.ts +6 -0
  150. package/pages/CreateSnapshot/useCreatedStores.js +5 -0
  151. package/pages/CreateSnapshot/useForm.d.ts +53 -0
  152. package/pages/CreateSnapshot/useForm.js +25 -0
  153. package/pages/CreateSnapshot/utils/index.d.ts +1 -0
  154. package/pages/CreateSnapshot/utils/index.js +3 -0
  155. package/pages/Instance/Clones/ClonesList/ConnectionModal/index.d.ts +10 -0
  156. package/pages/Instance/Clones/ClonesList/ConnectionModal/index.js +74 -0
  157. package/pages/Instance/Clones/ClonesList/MenuCell/index.d.ts +11 -0
  158. package/pages/Instance/Clones/ClonesList/MenuCell/index.js +49 -0
  159. package/pages/Instance/Clones/ClonesList/MenuCell/utils.d.ts +3 -0
  160. package/pages/Instance/Clones/ClonesList/MenuCell/utils.js +18 -0
  161. package/pages/Instance/Clones/ClonesList/index.d.ts +9 -0
  162. package/pages/Instance/Clones/ClonesList/index.js +96 -0
  163. package/pages/Instance/{components → Clones}/ClonesList/styles.module.scss +10 -0
  164. package/pages/Instance/Clones/ClonesModal/index.d.ts +4 -0
  165. package/pages/Instance/Clones/ClonesModal/index.js +38 -0
  166. package/pages/Instance/Clones/ClonesModal/utils.d.ts +7 -0
  167. package/pages/Instance/Clones/ClonesModal/utils.js +14 -0
  168. package/pages/Instance/Clones/Header/Item/index.d.ts +7 -0
  169. package/pages/Instance/Clones/Header/Item/index.js +5 -0
  170. package/pages/Instance/Clones/Header/index.d.ts +9 -0
  171. package/pages/Instance/Clones/Header/index.js +16 -0
  172. package/pages/Instance/Clones/Header/styles.module.scss +4 -1
  173. package/pages/Instance/Clones/index.d.ts +8 -0
  174. package/pages/Instance/Clones/index.js +64 -0
  175. package/pages/Instance/Configuration/Header/index.d.ts +11 -0
  176. package/pages/Instance/Configuration/Header/index.js +17 -0
  177. package/pages/Instance/Configuration/InputWithTooltip/index.d.ts +32 -0
  178. package/pages/Instance/Configuration/InputWithTooltip/index.js +64 -0
  179. package/pages/Instance/Configuration/ResponseMessage/index.d.ts +5 -0
  180. package/pages/Instance/Configuration/ResponseMessage/index.js +43 -0
  181. package/pages/Instance/Configuration/configOptions.d.ts +9 -0
  182. package/pages/Instance/Configuration/configOptions.js +59 -0
  183. package/pages/Instance/Configuration/index.d.ts +10 -0
  184. package/pages/Instance/Configuration/index.js +547 -0
  185. package/pages/Instance/Configuration/tooltipText.d.ts +20 -0
  186. package/pages/Instance/Configuration/tooltipText.js +21 -0
  187. package/pages/Instance/Configuration/useForm.d.ts +82 -0
  188. package/pages/Instance/Configuration/useForm.js +74 -0
  189. package/pages/Instance/Configuration/utils/index.d.ts +22 -0
  190. package/pages/Instance/Configuration/utils/index.js +105 -0
  191. package/pages/Instance/InactiveInstance/index.d.ts +6 -0
  192. package/pages/Instance/InactiveInstance/index.js +65 -0
  193. package/pages/Instance/InactiveInstance/utils.d.ts +2 -0
  194. package/pages/Instance/InactiveInstance/utils.js +7 -0
  195. package/pages/Instance/Info/Connection/ConnectModal/Content/index.d.ts +4 -0
  196. package/pages/Instance/Info/Connection/ConnectModal/Content/index.js +73 -0
  197. package/pages/Instance/Info/Connection/ConnectModal/Content/utils.d.ts +3 -0
  198. package/pages/Instance/Info/Connection/ConnectModal/Content/utils.js +20 -0
  199. package/pages/Instance/Info/Connection/ConnectModal/index.d.ts +6 -0
  200. package/pages/Instance/Info/Connection/ConnectModal/index.js +17 -0
  201. package/pages/Instance/Info/Connection/index.d.ts +4 -0
  202. package/pages/Instance/Info/Connection/index.js +44 -0
  203. package/pages/Instance/Info/Details/index.d.ts +2 -0
  204. package/pages/Instance/Info/Details/index.js +6 -0
  205. package/pages/Instance/Info/Disks/Disk/ActionsMenu/index.d.ts +8 -0
  206. package/pages/Instance/Info/Disks/Disk/ActionsMenu/index.js +47 -0
  207. package/pages/Instance/Info/Disks/Disk/Marker/index.d.ts +6 -0
  208. package/pages/Instance/Info/Disks/Disk/Marker/index.js +15 -0
  209. package/pages/Instance/Info/Disks/Disk/ProgressBar/PointerIcon.d.ts +5 -0
  210. package/pages/Instance/Info/Disks/Disk/ProgressBar/PointerIcon.js +2 -0
  211. package/pages/Instance/Info/Disks/Disk/ProgressBar/index.d.ts +8 -0
  212. package/pages/Instance/Info/Disks/Disk/ProgressBar/index.js +45 -0
  213. package/pages/Instance/Info/Disks/Disk/Status/index.d.ts +6 -0
  214. package/pages/Instance/Info/Disks/Disk/Status/index.js +52 -0
  215. package/pages/Instance/Info/Disks/Disk/index.d.ts +15 -0
  216. package/pages/Instance/Info/Disks/Disk/index.js +71 -0
  217. package/pages/Instance/Info/Disks/index.d.ts +4 -0
  218. package/pages/Instance/Info/Disks/index.js +24 -0
  219. package/pages/Instance/Info/Icons/index.d.ts +7 -0
  220. package/pages/Instance/Info/Icons/index.js +3 -0
  221. package/pages/Instance/Info/Retrieval/RefreshFailedAlert/index.d.ts +4 -0
  222. package/pages/Instance/Info/Retrieval/RefreshFailedAlert/index.js +15 -0
  223. package/pages/Instance/Info/Retrieval/RetrievalModal/index.d.ts +10 -0
  224. package/pages/Instance/Info/Retrieval/RetrievalModal/index.js +11 -0
  225. package/pages/Instance/Info/Retrieval/RetrievalTable/index.d.ts +6 -0
  226. package/pages/Instance/Info/Retrieval/RetrievalTable/index.js +6 -0
  227. package/pages/Instance/Info/Retrieval/index.d.ts +4 -0
  228. package/pages/Instance/Info/Retrieval/index.js +47 -0
  229. package/pages/Instance/Info/Retrieval/utils.d.ts +2 -0
  230. package/pages/Instance/Info/Retrieval/utils.js +12 -0
  231. package/pages/Instance/Info/Snapshots/Calendar/Day/index.d.ts +11 -0
  232. package/pages/Instance/Info/Snapshots/Calendar/Day/index.js +71 -0
  233. package/pages/Instance/Info/Snapshots/Calendar/index.d.ts +8 -0
  234. package/pages/Instance/Info/Snapshots/Calendar/index.js +67 -0
  235. package/pages/Instance/Info/Snapshots/Calendar/utils.d.ts +27 -0
  236. package/pages/Instance/Info/Snapshots/Calendar/utils.js +41 -0
  237. package/pages/Instance/Info/Snapshots/TimeLine/Day/index.d.ts +6 -0
  238. package/pages/Instance/Info/Snapshots/TimeLine/Day/index.js +58 -0
  239. package/pages/Instance/Info/Snapshots/TimeLine/index.d.ts +2 -0
  240. package/pages/Instance/Info/Snapshots/TimeLine/index.js +32 -0
  241. package/pages/Instance/Info/Snapshots/index.d.ts +4 -0
  242. package/pages/Instance/Info/Snapshots/index.js +40 -0
  243. package/pages/Instance/Info/Snapshots/utils.d.ts +34 -0
  244. package/pages/Instance/Info/Snapshots/utils.js +26 -0
  245. package/pages/Instance/Info/Status/InstanceResponseModal/index.d.ts +9 -0
  246. package/pages/Instance/Info/Status/InstanceResponseModal/index.js +12 -0
  247. package/pages/Instance/Info/Status/index.d.ts +4 -0
  248. package/pages/Instance/Info/Status/index.js +31 -0
  249. package/pages/Instance/Info/Status/utils.d.ts +8 -0
  250. package/pages/Instance/Info/Status/utils.js +23 -0
  251. package/pages/Instance/Info/components/Property/index.d.ts +11 -0
  252. package/pages/Instance/Info/components/Property/index.js +14 -0
  253. package/pages/Instance/Info/components/Section/index.d.ts +8 -0
  254. package/pages/Instance/Info/components/Section/index.js +18 -0
  255. package/pages/Instance/Info/components/ValueStatus/index.d.ts +9 -0
  256. package/pages/Instance/Info/components/ValueStatus/index.js +18 -0
  257. package/pages/Instance/Info/index.d.ts +2 -0
  258. package/pages/Instance/Info/index.js +76 -0
  259. package/pages/Instance/Snapshots/components/SnapshotHeader/index.d.ts +11 -0
  260. package/pages/Instance/Snapshots/components/SnapshotHeader/index.js +36 -0
  261. package/pages/Instance/Snapshots/components/SnapshotsList/index.d.ts +11 -0
  262. package/pages/Instance/Snapshots/components/SnapshotsList/index.js +157 -0
  263. package/pages/Instance/Snapshots/components/SnapshotsModal/utils.d.ts +7 -0
  264. package/{components/HorizontalScrollContainer/utils.ts → pages/Instance/Snapshots/components/SnapshotsModal/utils.js} +8 -9
  265. package/pages/Instance/Snapshots/components/SnapshotsTable/index.d.ts +6 -0
  266. package/pages/Instance/Snapshots/components/SnapshotsTable/index.js +125 -0
  267. package/pages/Instance/Snapshots/index.d.ts +6 -0
  268. package/pages/Instance/Snapshots/index.js +92 -0
  269. package/pages/Instance/Snapshots/utils/index.d.ts +16 -0
  270. package/pages/Instance/Snapshots/utils/index.js +30 -0
  271. package/pages/Instance/SnapshotsModal/index.d.ts +4 -0
  272. package/pages/Instance/SnapshotsModal/index.js +81 -0
  273. package/pages/Instance/Tabs/PlatformTabs.d.ts +10 -0
  274. package/pages/Instance/Tabs/PlatformTabs.js +51 -0
  275. package/pages/Instance/Tabs/index.d.ts +26 -0
  276. package/pages/Instance/Tabs/index.js +75 -0
  277. package/pages/Instance/Tabs/styles.d.ts +1 -0
  278. package/pages/Instance/Tabs/styles.js +62 -0
  279. package/pages/Instance/components/ErrorStub/index.d.ts +9 -0
  280. package/pages/Instance/components/ErrorStub/index.js +42 -0
  281. package/pages/Instance/components/ModalReloadButton/index.d.ts +7 -0
  282. package/pages/Instance/components/ModalReloadButton/index.js +22 -0
  283. package/pages/Instance/components/Tags/Tag/index.d.ts +7 -0
  284. package/pages/Instance/components/Tags/Tag/index.js +35 -0
  285. package/pages/Instance/components/Tags/index.d.ts +8 -0
  286. package/pages/Instance/components/Tags/index.js +16 -0
  287. package/pages/Instance/context.d.ts +38 -0
  288. package/pages/Instance/{ClonesModal/utils.ts → context.js} +5 -15
  289. package/pages/Instance/index.d.ts +8 -0
  290. package/pages/Instance/index.js +94 -0
  291. package/pages/Instance/stores/ClonesModal.d.ts +13 -0
  292. package/pages/Instance/stores/ClonesModal.js +24 -0
  293. package/pages/Instance/stores/Main.d.ts +141 -0
  294. package/pages/Instance/stores/Main.js +302 -0
  295. package/pages/Instance/stores/SnapshotsModal.d.ts +13 -0
  296. package/pages/Instance/stores/SnapshotsModal.js +24 -0
  297. package/pages/Instance/styles.scss +1 -4
  298. package/pages/Instance/useCreatedStores.d.ts +10 -0
  299. package/pages/Instance/useCreatedStores.js +9 -0
  300. package/pages/Logs/Icons/PlusIcon.d.ts +2 -0
  301. package/pages/Logs/Icons/PlusIcon.js +2 -0
  302. package/pages/Logs/constants/index.d.ts +5 -0
  303. package/pages/Logs/constants/index.js +5 -0
  304. package/pages/Logs/hooks/useWsScroll.d.ts +1 -0
  305. package/pages/Logs/hooks/useWsScroll.js +37 -0
  306. package/pages/Logs/index.d.ts +6 -0
  307. package/pages/Logs/index.js +200 -0
  308. package/pages/Logs/utils/index.d.ts +2 -0
  309. package/pages/Logs/utils/index.js +15 -0
  310. package/pages/Logs/wsLogs.d.ts +3 -0
  311. package/pages/Logs/wsLogs.js +92 -0
  312. package/pages/Logs/wsSnackbar.d.ts +1 -0
  313. package/pages/Logs/wsSnackbar.js +25 -0
  314. package/pages/Snapshots/Snapshot/DestorySnapshotModal/index.d.ts +12 -0
  315. package/pages/Snapshots/Snapshot/DestorySnapshotModal/index.js +69 -0
  316. package/pages/Snapshots/Snapshot/context.d.ts +23 -0
  317. package/pages/Snapshots/Snapshot/context.js +3 -0
  318. package/pages/Snapshots/Snapshot/index.d.ts +9 -0
  319. package/pages/Snapshots/Snapshot/index.js +171 -0
  320. package/pages/Snapshots/Snapshot/stores/Main.d.ts +33 -0
  321. package/pages/Snapshots/Snapshot/stores/Main.js +71 -0
  322. package/pages/Snapshots/Snapshot/useCreatedStores.d.ts +6 -0
  323. package/pages/Snapshots/Snapshot/useCreatedStores.js +5 -0
  324. package/stores/Snapshots.d.ts +24 -0
  325. package/stores/Snapshots.js +59 -0
  326. package/styles/colors.d.ts +60 -0
  327. package/styles/colors.js +66 -0
  328. package/styles/icons.d.ts +63 -0
  329. package/styles/icons.js +69 -0
  330. package/styles/styles.d.ts +1 -0
  331. package/styles/styles.js +83 -0
  332. package/styles/theme.d.ts +1 -0
  333. package/styles/theme.js +50 -0
  334. package/styles/vars.d.ts +25 -0
  335. package/styles/{vars.ts → vars.js} +20 -28
  336. package/types/api/endpoints/createBranch.d.ts +12 -0
  337. package/types/api/endpoints/createBranch.js +1 -0
  338. package/types/api/endpoints/createClone.d.ts +13 -0
  339. package/types/api/endpoints/createClone.js +1 -0
  340. package/types/api/endpoints/createSnapshot.d.ts +5 -0
  341. package/types/api/endpoints/createSnapshot.js +1 -0
  342. package/types/api/endpoints/deleteBranch.d.ts +4 -0
  343. package/types/api/endpoints/deleteBranch.js +1 -0
  344. package/types/api/endpoints/destroyClone.d.ts +7 -0
  345. package/types/api/endpoints/destroyClone.js +1 -0
  346. package/types/api/endpoints/destroySnapshot.d.ts +4 -0
  347. package/types/api/endpoints/destroySnapshot.js +1 -0
  348. package/types/api/endpoints/getBranchSnapshot.d.ts +5 -0
  349. package/types/api/endpoints/getBranchSnapshot.js +1 -0
  350. package/types/api/endpoints/getBranches.d.ts +18 -0
  351. package/types/api/endpoints/getBranches.js +5 -0
  352. package/types/api/endpoints/getClone.d.ts +8 -0
  353. package/types/api/endpoints/getClone.js +1 -0
  354. package/types/api/endpoints/getConfig.d.ts +5 -0
  355. package/types/api/endpoints/getConfig.js +1 -0
  356. package/types/api/endpoints/getEngine.d.ts +10 -0
  357. package/types/api/endpoints/getEngine.js +1 -0
  358. package/types/api/endpoints/getFullConfig.d.ts +4 -0
  359. package/types/api/endpoints/getFullConfig.js +1 -0
  360. package/types/api/endpoints/getInstance.d.ts +7 -0
  361. package/types/api/endpoints/getInstance.js +1 -0
  362. package/types/api/endpoints/getInstanceRetrieval.d.ts +7 -0
  363. package/types/api/endpoints/getInstanceRetrieval.js +1 -0
  364. package/types/api/endpoints/getSeImages.d.ts +19 -0
  365. package/types/api/endpoints/getSeImages.js +1 -0
  366. package/types/api/endpoints/getSnapshotList.d.ts +10 -0
  367. package/types/api/endpoints/getSnapshotList.js +1 -0
  368. package/types/api/endpoints/getSnapshots.d.ts +8 -0
  369. package/types/api/endpoints/getSnapshots.js +1 -0
  370. package/types/api/endpoints/getWSToken.d.ts +7 -0
  371. package/types/api/endpoints/getWSToken.js +1 -0
  372. package/types/api/endpoints/initWS.d.ts +1 -0
  373. package/types/api/endpoints/initWS.js +1 -0
  374. package/types/api/endpoints/refreshInstance.d.ts +6 -0
  375. package/types/api/endpoints/refreshInstance.js +1 -0
  376. package/types/api/endpoints/resetClone.d.ts +8 -0
  377. package/types/api/endpoints/resetClone.js +1 -0
  378. package/types/api/endpoints/testDbSource.d.ts +22 -0
  379. package/types/api/endpoints/testDbSource.js +23 -0
  380. package/types/api/endpoints/updateClone.d.ts +10 -0
  381. package/types/api/endpoints/updateClone.js +1 -0
  382. package/types/api/endpoints/updateConfig.d.ts +5 -0
  383. package/types/api/endpoints/updateConfig.js +1 -0
  384. package/types/api/entities/branchSnapshot.d.ts +6 -0
  385. package/types/api/entities/branchSnapshot.js +1 -0
  386. package/types/api/entities/branchSnapshots.d.ts +15 -0
  387. package/types/api/entities/branchSnapshots.js +7 -0
  388. package/types/api/entities/clone.d.ts +56 -0
  389. package/{components/Text/index.tsx → types/api/entities/clone.js} +8 -22
  390. package/types/api/entities/config.d.ts +72 -0
  391. package/types/api/entities/config.js +35 -0
  392. package/types/api/entities/createBranch.d.ts +5 -0
  393. package/types/api/entities/createBranch.js +1 -0
  394. package/types/api/entities/createSnapshot.d.ts +5 -0
  395. package/types/api/entities/createSnapshot.js +1 -0
  396. package/types/api/entities/dbSource.d.ts +13 -0
  397. package/types/api/entities/dbSource.js +1 -0
  398. package/types/api/entities/instance.d.ts +114 -0
  399. package/types/api/entities/instance.js +31 -0
  400. package/types/api/entities/instanceRetrieval.d.ts +42 -0
  401. package/types/api/entities/instanceRetrieval.js +19 -0
  402. package/types/api/entities/instanceState.d.ts +114 -0
  403. package/types/api/entities/instanceState.js +42 -0
  404. package/types/api/entities/pool.d.ts +18 -0
  405. package/{utils/numbers.ts → types/api/entities/pool.js} +1 -5
  406. package/types/api/entities/snapshot.d.ts +27 -0
  407. package/types/api/entities/snapshot.js +6 -0
  408. package/types/api/entities/wsToken.d.ts +5 -0
  409. package/types/api/entities/wsToken.js +1 -0
  410. package/utils/api.d.ts +1 -0
  411. package/utils/api.js +28 -0
  412. package/utils/clone.d.ts +13 -0
  413. package/utils/clone.js +21 -0
  414. package/utils/connection.d.ts +5 -0
  415. package/utils/connection.js +28 -0
  416. package/utils/date.d.ts +18 -0
  417. package/utils/date.js +40 -0
  418. package/utils/instance.d.ts +5 -0
  419. package/utils/instance.js +11 -0
  420. package/utils/numbers.d.ts +1 -0
  421. package/utils/{strings.ts → numbers.js} +4 -5
  422. package/utils/react.d.ts +5 -0
  423. package/utils/react.js +8 -0
  424. package/utils/snapshot.d.ts +5 -0
  425. package/utils/snapshot.js +6 -0
  426. package/utils/strings.d.ts +1 -0
  427. package/utils/strings.js +10 -0
  428. package/utils/units.d.ts +5 -0
  429. package/utils/units.js +15 -0
  430. package/.gitlab-ci.yml +0 -60
  431. package/components/AlertSnackbar/index.tsx +0 -23
  432. package/components/AlertSnackbar/useAlertSnackbar.tsx +0 -65
  433. package/components/Button/index.tsx +0 -79
  434. package/components/Button2/index.tsx +0 -43
  435. package/components/DestroyCloneModal/index.tsx +0 -56
  436. package/components/DestroyCloneRestrictionModal/index.tsx +0 -50
  437. package/components/ErrorStub/index.tsx +0 -83
  438. package/components/FormattedText/index.tsx +0 -44
  439. package/components/GatewayLink/index.tsx +0 -33
  440. package/components/HorizontalScrollContainer/index.tsx +0 -131
  441. package/components/ImportantText/index.tsx +0 -29
  442. package/components/Link2/index.tsx +0 -31
  443. package/components/MenuButton/index.tsx +0 -80
  444. package/components/Modal/index.tsx +0 -93
  445. package/components/ResetCloneModal/index.tsx +0 -154
  446. package/components/SectionTitle/index.tsx +0 -74
  447. package/components/Select/index.tsx +0 -42
  448. package/components/SimpleModalControls/index.tsx +0 -56
  449. package/components/Spinner/icon.tsx +0 -29
  450. package/components/Spinner/index.tsx +0 -16
  451. package/components/Status/index.tsx +0 -61
  452. package/components/StubContainer/index.tsx +0 -41
  453. package/components/StubSpinner/index.tsx +0 -49
  454. package/components/StubSpinnerFlex/index.tsx +0 -20
  455. package/components/SyntaxHighlight/index.tsx +0 -107
  456. package/components/Table/RowMenu/index.tsx +0 -111
  457. package/components/Table/index.tsx +0 -140
  458. package/components/TextField/index.tsx +0 -117
  459. package/components/Tooltip/index.tsx +0 -52
  460. package/config/index.ts +0 -32
  461. package/config/links.ts +0 -6
  462. package/craco.config.js +0 -80
  463. package/helpers/getEntropy.ts +0 -232
  464. package/helpers/localStorage.ts +0 -15
  465. package/helpers/request.ts +0 -47
  466. package/hooks/useWindowDimensions.ts +0 -16
  467. package/icons/ArrowDropDown/index.tsx +0 -29
  468. package/icons/Circle/index.tsx +0 -27
  469. package/icons/External/index.tsx +0 -14
  470. package/icons/Info/index.tsx +0 -12
  471. package/icons/Renewable/index.tsx +0 -65
  472. package/icons/Shield/index.tsx +0 -33
  473. package/icons/Warning/index.tsx +0 -29
  474. package/pages/Clone/Status/index.tsx +0 -73
  475. package/pages/Clone/context.ts +0 -22
  476. package/pages/Clone/index.tsx +0 -634
  477. package/pages/Clone/stores/Main.ts +0 -206
  478. package/pages/Clone/useCreatedStores.ts +0 -11
  479. package/pages/Configuration/Header/index.tsx +0 -84
  480. package/pages/Configuration/InputWithTooltip/index.tsx +0 -240
  481. package/pages/Configuration/ResponseMessage/index.tsx +0 -71
  482. package/pages/Configuration/configOptions.ts +0 -60
  483. package/pages/Configuration/index.tsx +0 -1184
  484. package/pages/Configuration/tooltipText.tsx +0 -157
  485. package/pages/Configuration/useForm.ts +0 -108
  486. package/pages/Configuration/utils/index.ts +0 -153
  487. package/pages/CreateClone/index.tsx +0 -311
  488. package/pages/CreateClone/stores/Main.ts +0 -107
  489. package/pages/CreateClone/useCreatedStores.ts +0 -11
  490. package/pages/CreateClone/useForm.ts +0 -36
  491. package/pages/Instance/Clones/Header/Item/index.tsx +0 -15
  492. package/pages/Instance/Clones/Header/index.tsx +0 -74
  493. package/pages/Instance/Clones/index.tsx +0 -135
  494. package/pages/Instance/ClonesModal/index.tsx +0 -71
  495. package/pages/Instance/InactiveInstance/index.tsx +0 -165
  496. package/pages/Instance/InactiveInstance/utils.ts +0 -9
  497. package/pages/Instance/Info/Connection/ConnectModal/Content/index.tsx +0 -176
  498. package/pages/Instance/Info/Connection/ConnectModal/Content/utils.ts +0 -24
  499. package/pages/Instance/Info/Connection/ConnectModal/index.tsx +0 -36
  500. package/pages/Instance/Info/Connection/index.tsx +0 -81
  501. package/pages/Instance/Info/Details/index.tsx +0 -20
  502. package/pages/Instance/Info/Disks/Disk/ActionsMenu/index.tsx +0 -100
  503. package/pages/Instance/Info/Disks/Disk/Marker/index.tsx +0 -26
  504. package/pages/Instance/Info/Disks/Disk/ProgressBar/PointerIcon.tsx +0 -20
  505. package/pages/Instance/Info/Disks/Disk/ProgressBar/index.tsx +0 -73
  506. package/pages/Instance/Info/Disks/Disk/Status/index.tsx +0 -75
  507. package/pages/Instance/Info/Disks/Disk/index.tsx +0 -168
  508. package/pages/Instance/Info/Disks/index.tsx +0 -65
  509. package/pages/Instance/Info/Icons/index.tsx +0 -39
  510. package/pages/Instance/Info/Retrieval/RefreshFailedAlert/index.tsx +0 -32
  511. package/pages/Instance/Info/Retrieval/RetrievalModal/index.tsx +0 -49
  512. package/pages/Instance/Info/Retrieval/RetrievalTable/index.tsx +0 -53
  513. package/pages/Instance/Info/Retrieval/index.tsx +0 -95
  514. package/pages/Instance/Info/Retrieval/utils.ts +0 -10
  515. package/pages/Instance/Info/Snapshots/Calendar/Day/index.tsx +0 -125
  516. package/pages/Instance/Info/Snapshots/Calendar/index.tsx +0 -133
  517. package/pages/Instance/Info/Snapshots/Calendar/utils.ts +0 -74
  518. package/pages/Instance/Info/Snapshots/TimeLine/Day/index.tsx +0 -79
  519. package/pages/Instance/Info/Snapshots/TimeLine/index.tsx +0 -57
  520. package/pages/Instance/Info/Snapshots/index.tsx +0 -97
  521. package/pages/Instance/Info/Snapshots/utils.ts +0 -18
  522. package/pages/Instance/Info/Status/InstanceResponseModal/index.tsx +0 -32
  523. package/pages/Instance/Info/Status/index.tsx +0 -85
  524. package/pages/Instance/Info/Status/utils.ts +0 -24
  525. package/pages/Instance/Info/components/Property/index.tsx +0 -32
  526. package/pages/Instance/Info/components/Section/index.tsx +0 -50
  527. package/pages/Instance/Info/components/ValueStatus/index.tsx +0 -51
  528. package/pages/Instance/Info/index.tsx +0 -129
  529. package/pages/Instance/SnapshotsModal/index.tsx +0 -169
  530. package/pages/Instance/SnapshotsModal/utils.ts +0 -17
  531. package/pages/Instance/Tabs/index.tsx +0 -98
  532. package/pages/Instance/components/ClonesList/ConnectionModal/index.tsx +0 -196
  533. package/pages/Instance/components/ClonesList/MenuCell/index.tsx +0 -98
  534. package/pages/Instance/components/ClonesList/MenuCell/utils.ts +0 -21
  535. package/pages/Instance/components/ClonesList/index.tsx +0 -189
  536. package/pages/Instance/components/ErrorStub/index.tsx +0 -77
  537. package/pages/Instance/components/ModalReloadButton/index.tsx +0 -43
  538. package/pages/Instance/components/Tags/Tag/index.tsx +0 -60
  539. package/pages/Instance/components/Tags/index.tsx +0 -42
  540. package/pages/Instance/context.ts +0 -39
  541. package/pages/Instance/index.tsx +0 -235
  542. package/pages/Instance/stores/ClonesModal.ts +0 -35
  543. package/pages/Instance/stores/Main.ts +0 -335
  544. package/pages/Instance/stores/SnapshotsModal.ts +0 -35
  545. package/pages/Instance/useCreatedStores.ts +0 -14
  546. package/pages/Logs/Icons/PlusIcon.tsx +0 -8
  547. package/pages/Logs/constants/index.ts +0 -7
  548. package/pages/Logs/hooks/useWsScroll.tsx +0 -44
  549. package/pages/Logs/index.tsx +0 -267
  550. package/pages/Logs/utils/index.ts +0 -20
  551. package/pages/Logs/wsLogs.ts +0 -110
  552. package/pages/Logs/wsSnackbar.ts +0 -27
  553. package/postgres.ai-shared-3.5.0.tgz +0 -0
  554. package/scripts/copy-assets.js +0 -30
  555. package/scripts/pack.js +0 -70
  556. package/stores/Snapshots.ts +0 -54
  557. package/styles/colors.ts +0 -67
  558. package/styles/icons.tsx +0 -1917
  559. package/styles/styles.ts +0 -87
  560. package/styles/theme.ts +0 -53
  561. package/types/api/endpoints/createClone.ts +0 -10
  562. package/types/api/endpoints/destroyClone.ts +0 -7
  563. package/types/api/endpoints/getClone.ts +0 -6
  564. package/types/api/endpoints/getConfig.ts +0 -6
  565. package/types/api/endpoints/getEngine.ts +0 -13
  566. package/types/api/endpoints/getFullConfig.ts +0 -4
  567. package/types/api/endpoints/getInstance.ts +0 -6
  568. package/types/api/endpoints/getInstanceRetrieval.ts +0 -6
  569. package/types/api/endpoints/getSeImages.ts +0 -22
  570. package/types/api/endpoints/getSnapshots.ts +0 -6
  571. package/types/api/endpoints/getWSToken.ts +0 -6
  572. package/types/api/endpoints/initWS.ts +0 -1
  573. package/types/api/endpoints/refreshInstance.ts +0 -4
  574. package/types/api/endpoints/resetClone.ts +0 -8
  575. package/types/api/endpoints/testDbSource.ts +0 -48
  576. package/types/api/endpoints/updateClone.ts +0 -10
  577. package/types/api/endpoints/updateConfig.ts +0 -6
  578. package/types/api/entities/clone.ts +0 -42
  579. package/types/api/entities/config.ts +0 -114
  580. package/types/api/entities/dbSource.ts +0 -13
  581. package/types/api/entities/instance.ts +0 -67
  582. package/types/api/entities/instanceRetrieval.ts +0 -46
  583. package/types/api/entities/instanceState.ts +0 -102
  584. package/types/api/entities/pool.ts +0 -27
  585. package/types/api/entities/snapshot.ts +0 -18
  586. package/types/api/entities/wsToken.ts +0 -7
  587. package/types/byte-size/index.d.ts +0 -22
  588. package/utils/api.ts +0 -30
  589. package/utils/clone.ts +0 -31
  590. package/utils/connection.ts +0 -38
  591. package/utils/date.ts +0 -87
  592. package/utils/instance.ts +0 -10
  593. package/utils/react.ts +0 -10
  594. package/utils/snapshot.ts +0 -4
  595. package/utils/units.ts +0 -23
  596. /package/pages/{Configuration → Instance/Configuration}/styles.module.scss +0 -0
@@ -1,311 +0,0 @@
1
- import cn from 'classnames'
2
- import { useEffect } from 'react'
3
- import { useHistory } from 'react-router-dom'
4
- import { observer } from 'mobx-react-lite'
5
- import { useTimer } from 'use-timer'
6
- import { Paper, FormControlLabel, Checkbox } from '@material-ui/core'
7
- import { Info as InfoIcon } from '@material-ui/icons'
8
-
9
- import { StubSpinner } from '@postgres.ai/shared/components/StubSpinnerFlex'
10
- import { TextField } from '@postgres.ai/shared/components/TextField'
11
- import { Select } from '@postgres.ai/shared/components/Select'
12
- import { Button } from '@postgres.ai/shared/components/Button'
13
- import { Spinner } from '@postgres.ai/shared/components/Spinner'
14
- import { ErrorStub } from '@postgres.ai/shared/components/ErrorStub'
15
- import { compareSnapshotsDesc } from '@postgres.ai/shared/utils/snapshot'
16
- import { round } from '@postgres.ai/shared/utils/numbers'
17
- import { formatBytesIEC } from '@postgres.ai/shared/utils/units'
18
- import { SectionTitle } from '@postgres.ai/shared/components/SectionTitle'
19
- import {
20
- MIN_ENTROPY,
21
- getEntropy,
22
- validatePassword,
23
- } from '@postgres.ai/shared/helpers/getEntropy'
24
-
25
- import { useCreatedStores, MainStoreApi } from './useCreatedStores'
26
- import { useForm, FormValues } from './useForm'
27
-
28
- import styles from './styles.module.scss'
29
-
30
- type Host = {
31
- instanceId: string
32
- routes: {
33
- clone: (cloneId: string) => string
34
- }
35
- api: MainStoreApi
36
- elements: {
37
- breadcrumbs: React.ReactNode
38
- }
39
- }
40
-
41
- type Props = Host
42
-
43
- export const CreateClone = observer((props: Props) => {
44
- const history = useHistory()
45
- const stores = useCreatedStores(props.api)
46
- const cloneError = stores.main.cloneError
47
- const timer = useTimer()
48
-
49
- // Form.
50
- const onSubmit = async (values: FormValues) => {
51
- if (!values.dbPassword || getEntropy(values.dbPassword) < MIN_ENTROPY) {
52
- formik.setFieldError(
53
- 'dbPassword',
54
- validatePassword(values.dbPassword, MIN_ENTROPY),
55
- )
56
- return
57
- }
58
-
59
- timer.start()
60
-
61
- const isSuccess = await stores.main.createClone(values)
62
-
63
- formik.setFieldError('dbPassword', '')
64
-
65
- if (!isSuccess || cloneError) {
66
- timer.pause()
67
- timer.reset()
68
- }
69
- }
70
-
71
- const formik = useForm(onSubmit)
72
-
73
- // Initial loading data.
74
- useEffect(() => {
75
- stores.main.load(props.instanceId)
76
- }, [])
77
-
78
- // Redirect when clone is created and stable.
79
- useEffect(() => {
80
- if (!stores.main.clone) return
81
- if (!stores.main.isCloneStable) return
82
-
83
- history.push(props.routes.clone(stores.main.clone.id))
84
- }, [stores.main.clone, stores.main.isCloneStable])
85
-
86
- // Snapshots.
87
- const sortedSnapshots = stores.main.snapshots.data
88
- ?.slice()
89
- .sort(compareSnapshotsDesc)
90
-
91
- useEffect(() => {
92
- const [firstSnapshot] = sortedSnapshots ?? []
93
- if (!firstSnapshot) return
94
-
95
- formik.setFieldValue('snapshotId', firstSnapshot.id)
96
- }, [Boolean(sortedSnapshots)])
97
-
98
- const headRendered = (
99
- <>
100
- {/* //TODO: make global reset styles. */}
101
- <style>{'p { margin: 0; }'}</style>
102
-
103
- {props.elements.breadcrumbs}
104
- <SectionTitle
105
- className={styles.title}
106
- tag="h1"
107
- level={1}
108
- text="Create clone"
109
- />
110
- </>
111
- )
112
-
113
- // Initial loading spinner.
114
- if (!stores.main.instance || !stores.main.snapshots.data)
115
- return (
116
- <>
117
- {headRendered}
118
-
119
- <StubSpinner />
120
- </>
121
- )
122
-
123
- // Instance getting error.
124
- if (stores.main.instanceError)
125
- return (
126
- <>
127
- {headRendered}
128
-
129
- <ErrorStub message={stores.main.instanceError} />
130
- </>
131
- )
132
-
133
- // Snapshots getting error.
134
- if (stores.main.snapshots.error)
135
- return <ErrorStub message={stores.main.snapshots.error} />
136
-
137
- const isCloneUnstable = Boolean(
138
- stores.main.clone && !stores.main.isCloneStable,
139
- )
140
- const isCreatingClone = formik.isSubmitting || isCloneUnstable
141
-
142
- return (
143
- <>
144
- {headRendered}
145
-
146
- <div className={styles.form}>
147
- {stores.main.cloneError && (
148
- <div className={styles.section}>
149
- <ErrorStub message={stores.main.cloneError} />
150
- </div>
151
- )}
152
-
153
- <div className={styles.section}>
154
- <TextField
155
- fullWidth
156
- label="Clone ID"
157
- value={formik.values.cloneId}
158
- onChange={(e) => formik.setFieldValue('cloneId', e.target.value)}
159
- error={Boolean(formik.errors.cloneId)}
160
- disabled={isCreatingClone}
161
- />
162
-
163
- <Select
164
- fullWidth
165
- label="Data state time *"
166
- value={formik.values.snapshotId}
167
- disabled={!sortedSnapshots || isCreatingClone}
168
- onChange={(e) => formik.setFieldValue('snapshotId', e.target.value)}
169
- error={Boolean(formik.errors.snapshotId)}
170
- items={
171
- sortedSnapshots?.map((snapshot, i) => {
172
- const isLatest = i === 0
173
- return {
174
- value: snapshot.id,
175
- children: (
176
- <>
177
- {snapshot.dataStateAt}
178
- {isLatest && (
179
- <span className={styles.snapshotTag}>Latest</span>
180
- )}
181
- </>
182
- ),
183
- }
184
- }) ?? []
185
- }
186
- />
187
-
188
- <p className={styles.remark}>
189
- By default latest snapshot of database is used. You can select&nbsp;
190
- different snapshots if earlier database state is needed
191
- </p>
192
- </div>
193
-
194
- <div className={styles.section}>
195
- <h2 className={styles.title}>Database credentials *</h2>
196
-
197
- <p className={styles.text}>
198
- Set custom credentials for the new clone. Save the password in
199
- reliable place, it can’t be read later.
200
- </p>
201
-
202
- <TextField
203
- fullWidth
204
- label="Database username *"
205
- value={formik.values.dbUser}
206
- onChange={(e) => formik.setFieldValue('dbUser', e.target.value)}
207
- error={Boolean(formik.errors.dbUser)}
208
- disabled={isCreatingClone}
209
- />
210
-
211
- <TextField
212
- fullWidth
213
- label="Database password *"
214
- type="password"
215
- value={formik.values.dbPassword}
216
- onChange={(e) => {
217
- formik.setFieldValue('dbPassword', e.target.value)
218
- if (formik.errors.dbPassword) {
219
- formik.setFieldError('dbPassword', '')
220
- }
221
- }}
222
- error={Boolean(formik.errors.dbPassword)}
223
- disabled={isCreatingClone}
224
- />
225
- <p
226
- className={cn(
227
- formik.errors.dbPassword && styles.error,
228
- styles.remark,
229
- )}
230
- >
231
- {formik.errors.dbPassword}
232
- </p>
233
- </div>
234
-
235
- <div className={styles.section}>
236
- <Paper className={styles.summary}>
237
- <InfoIcon className={styles.summaryIcon} />
238
-
239
- <div className={styles.params}>
240
- <p className={styles.param}>
241
- <span>Data size:</span>
242
- <strong>
243
- {stores.main.instance.state?.dataSize
244
- ? formatBytesIEC(stores.main.instance.state.dataSize)
245
- : '-'}
246
- </strong>
247
- </p>
248
-
249
- <p className={styles.param}>
250
- <span>Expected cloning time:</span>
251
- <strong>
252
- {round(
253
- stores.main.instance.state?.cloning
254
- .expectedCloningTime as number,
255
- 2,
256
- )}{' '}
257
- s
258
- </strong>
259
- </p>
260
- </div>
261
- </Paper>
262
- </div>
263
-
264
- <div className={styles.section}>
265
- <FormControlLabel
266
- label="Enable deletion protection"
267
- control={
268
- <Checkbox
269
- checked={formik.values.isProtected}
270
- onChange={(e) =>
271
- formik.setFieldValue('isProtected', e.target.checked)
272
- }
273
- name="protected"
274
- disabled={isCreatingClone}
275
- />
276
- }
277
- />
278
-
279
- <p className={styles.remark}>
280
- When enabled no one can delete this clone and automated deletion is
281
- also disabled.
282
- <br />
283
- Please be careful: abandoned clones with this checkbox enabled may
284
- cause out-of-disk-space events. Check disk space on daily basis and
285
- delete this clone once the work is done.
286
- </p>
287
- </div>
288
-
289
- <div className={styles.section}>
290
- <div className={styles.controls}>
291
- <Button
292
- onClick={formik.submitForm}
293
- variant="primary"
294
- size="medium"
295
- isDisabled={isCreatingClone}
296
- >
297
- Create clone
298
- {isCreatingClone && (
299
- <Spinner size="sm" className={styles.spinner} />
300
- )}
301
- </Button>
302
-
303
- {isCreatingClone && (
304
- <p className={styles.elapsedTime}>Elapsed time: {timer.time} s</p>
305
- )}
306
- </div>
307
- </div>
308
- </div>
309
- </>
310
- )
311
- })
@@ -1,107 +0,0 @@
1
- import { makeAutoObservable } from 'mobx'
2
-
3
- import { Instance } from '@postgres.ai/shared/types/api/entities/instance'
4
- import { Clone } from '@postgres.ai/shared/types/api/entities/clone'
5
- import { GetInstance } from '@postgres.ai/shared/types/api/endpoints/getInstance'
6
- import { CreateClone } from '@postgres.ai/shared/types/api/endpoints/createClone'
7
- import { GetClone } from '@postgres.ai/shared/types/api/endpoints/getClone'
8
- import {
9
- SnapshotsStore,
10
- SnapshotsApi,
11
- } from '@postgres.ai/shared/stores/Snapshots'
12
- import { getTextFromUnknownApiError } from '@postgres.ai/shared/utils/api'
13
- import { checkIsCloneStable } from '@postgres.ai/shared/utils/clone'
14
-
15
- import { FormValues } from '../useForm'
16
-
17
- const UNSTABLE_CLONE_UPDATE_TIMEOUT = 1000
18
-
19
- export type MainStoreApi = SnapshotsApi & {
20
- getInstance: GetInstance
21
- createClone: CreateClone
22
- getClone: GetClone
23
- }
24
-
25
- export class MainStore {
26
- instance: Instance | null = null
27
- instanceError: string | null = null
28
-
29
- clone: Clone | null = null
30
- cloneError: string | null = null
31
-
32
- private cloneUpdateTimeout?: number
33
-
34
- private readonly api: MainStoreApi
35
-
36
- readonly snapshots: SnapshotsStore
37
-
38
- constructor(api: MainStoreApi) {
39
- makeAutoObservable(this)
40
-
41
- this.api = api
42
- this.snapshots = new SnapshotsStore(api)
43
- }
44
-
45
- get isCloneStable() {
46
- if (!this.clone) return
47
- return checkIsCloneStable(this.clone)
48
- }
49
-
50
- load = async (instanceId: string) => {
51
- const [instance, isLoadedSnapshots] = await Promise.all([
52
- this.api.getInstance({ instanceId }),
53
- this.snapshots.load(instanceId),
54
- ])
55
-
56
- if (instance.response) this.instance = instance.response
57
- if (instance.error)
58
- this.instanceError = await getTextFromUnknownApiError(instance.error)
59
-
60
- return Boolean(instance.response) && isLoadedSnapshots
61
- }
62
-
63
- createClone = async (data: FormValues) => {
64
- if (!this.instance) return false
65
-
66
- const { response, error } = await this.api.createClone({
67
- ...data,
68
- instanceId: this.instance.id,
69
- })
70
-
71
- if (response) {
72
- this.clone = response
73
-
74
- this.updateCloneUntilStable({
75
- instanceId: this.instance.id,
76
- cloneId: this.clone.id,
77
- })
78
- }
79
-
80
- if (error)
81
- this.cloneError = await error.json().then((err) => err?.message || err)
82
-
83
- return Boolean(response)
84
- }
85
-
86
- private updateCloneUntilStable = async (args: {
87
- instanceId: string
88
- cloneId: string
89
- }) => {
90
- window.clearTimeout(this.cloneUpdateTimeout)
91
-
92
- const { response, error } = await this.api.getClone(args)
93
-
94
- if (response) {
95
- this.clone = response
96
-
97
- if (!this.isCloneStable)
98
- this.cloneUpdateTimeout = window.setTimeout(
99
- () => this.updateCloneUntilStable(args),
100
- UNSTABLE_CLONE_UPDATE_TIMEOUT,
101
- )
102
- }
103
-
104
- if (error)
105
- this.cloneError = await error.json().then((err) => err?.message || err)
106
- }
107
- }
@@ -1,11 +0,0 @@
1
- import { useMemo } from 'react'
2
-
3
- import { MainStore, MainStoreApi } from './stores/Main'
4
-
5
- export const useCreatedStores = (api: MainStoreApi) => ({
6
- main: useMemo(() => new MainStore(api), []),
7
- })
8
-
9
- export type Stores = ReturnType<typeof useCreatedStores>
10
-
11
- export type { MainStoreApi }
@@ -1,36 +0,0 @@
1
- import { useFormik } from 'formik'
2
- import * as Yup from 'yup'
3
-
4
- export type FormValues = {
5
- cloneId: string
6
- snapshotId: string
7
- dbUser: string
8
- dbPassword: string
9
- isProtected: boolean
10
- }
11
-
12
- const Schema = Yup.object().shape({
13
- cloneId: Yup.string(),
14
- snapshotId: Yup.string().required('Date state time is required'),
15
- dbUser: Yup.string().required('Database username is required'),
16
- dbPassword: Yup.string().required('Database password is required'),
17
- isProtected: Yup.boolean(),
18
- })
19
-
20
- export const useForm = (onSubmit: (values: FormValues) => void) => {
21
- const formik = useFormik<FormValues>({
22
- initialValues: {
23
- cloneId: '',
24
- snapshotId: '',
25
- dbUser: '',
26
- dbPassword: '',
27
- isProtected: false,
28
- },
29
- validationSchema: Schema,
30
- onSubmit,
31
- validateOnBlur: false,
32
- validateOnChange: false,
33
- })
34
-
35
- return formik
36
- }
@@ -1,15 +0,0 @@
1
- import styles from './styles.module.scss'
2
-
3
- type Props = {
4
- value: React.ReactNode
5
- children: React.ReactNode
6
- }
7
-
8
- export const Item = (props: Props) => {
9
- return (
10
- <div className={styles.root}>
11
- <div className={styles.value}>{props.value}</div>
12
- <div className={styles.description}>{props.children}</div>
13
- </div>
14
- )
15
- }
@@ -1,74 +0,0 @@
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
-
8
- import { formatBytesIEC } from '@postgres.ai/shared/utils/units'
9
-
10
- import { Item } from './Item'
11
-
12
- import styles from './styles.module.scss'
13
-
14
- type Props = {
15
- expectedCloningTimeS: number
16
- logicalSize: number | null
17
- clonesCount: number
18
- clonesCountLastMonth?: number
19
- }
20
-
21
- export const Header = (props: Props) => {
22
- const {
23
- expectedCloningTimeS,
24
- logicalSize,
25
- clonesCount,
26
- clonesCountLastMonth,
27
- } = props
28
-
29
- return (
30
- <div className={styles.root}>
31
- <Item value={expectedCloningTimeS ? `${expectedCloningTimeS} s` : '-'}>
32
- average
33
- <br />
34
- cloning time
35
- </Item>
36
-
37
- <Item
38
- value={
39
- logicalSize ? formatBytesIEC(logicalSize, { precision: 2 }) : '-'
40
- }
41
- >
42
- logical
43
- <br />
44
- data size
45
- </Item>
46
-
47
- <Item value={clonesCount}>
48
- clones
49
- <br />
50
- now
51
- </Item>
52
-
53
- <Item
54
- value={
55
- logicalSize
56
- ? formatBytesIEC(logicalSize * clonesCount, { precision: 2 })
57
- : '-'
58
- }
59
- >
60
- total
61
- <br />
62
- size of clones
63
- </Item>
64
-
65
- {clonesCountLastMonth && (
66
- <Item value={clonesCountLastMonth}>
67
- clones
68
- <br />
69
- in last month
70
- </Item>
71
- )}
72
- </div>
73
- )
74
- }
@@ -1,135 +0,0 @@
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
-
8
- import { useState } from 'react'
9
- import { makeStyles, Theme, useMediaQuery } from '@material-ui/core'
10
- import { useHistory } from 'react-router-dom'
11
- import { observer } from 'mobx-react-lite'
12
-
13
- import { SectionTitle } from '@postgres.ai/shared/components/SectionTitle'
14
- import { Button } from '@postgres.ai/shared/components/Button2'
15
- import { round } from '@postgres.ai/shared/utils/numbers'
16
- import { Tooltip } from '@postgres.ai/shared/components/Tooltip'
17
- import { InfoIcon } from '@postgres.ai/shared/icons/Info'
18
-
19
- import { useStores, useHost } from '@postgres.ai/shared/pages/Instance/context'
20
-
21
- import { ClonesList } from '../components/ClonesList'
22
-
23
- import { Header } from './Header'
24
-
25
- const SHORT_LIST_SIZE = 3
26
-
27
- const useStyles = makeStyles(
28
- (theme) => ({
29
- root: {
30
- width: 0,
31
- flex: '1 1 100%',
32
- marginRight: '40px',
33
- height: '100%',
34
-
35
- [theme.breakpoints.down('sm')]: {
36
- width: '100%',
37
- marginRight: 0,
38
- },
39
- },
40
- tableTitle: {
41
- marginTop: '5px',
42
- },
43
- listSizeButton: {
44
- marginTop: '12px',
45
- },
46
- infoIcon: {
47
- height: '12px',
48
- width: '12px',
49
- marginLeft: '8px',
50
- color: '#808080',
51
- },
52
- }),
53
- { index: 1 },
54
- )
55
-
56
- export const Clones = observer(() => {
57
- const classes = useStyles()
58
- const history = useHistory()
59
- const isMobile = useMediaQuery<Theme>((theme) => theme.breakpoints.down('sm'))
60
- const [isShortListForMobile, setIsShortListForMobile] = useState(true)
61
-
62
- const stores = useStores()
63
- const host = useHost()
64
-
65
- const { instance } = stores.main
66
- if (!instance || !instance.state) return null
67
-
68
- const isShortList = isMobile && isShortListForMobile
69
- const toggleListSize = () => setIsShortListForMobile(!isShortListForMobile)
70
-
71
- const goToCloneAddPage = () => history.push(host.routes.createClone())
72
-
73
- const showListSizeButton =
74
- instance.state?.cloning.clones?.length > SHORT_LIST_SIZE && isMobile
75
-
76
- const isLoadingSnapshots = stores.main.snapshots.isLoading
77
- const hasSnapshots = Boolean(stores.main.snapshots.data?.length)
78
- const canCreateClone = hasSnapshots && !stores.main.isDisabledInstance
79
-
80
- return (
81
- <div className={classes.root}>
82
- <SectionTitle level={2} tag="h2" text="Cloning summary" />
83
-
84
- <Header
85
- expectedCloningTimeS={round(
86
- instance.state.cloning.expectedCloningTime,
87
- 2,
88
- )}
89
- logicalSize={instance.state.dataSize}
90
- clonesCount={instance.state.cloning.clones.length}
91
- />
92
-
93
- <SectionTitle
94
- className={classes.tableTitle}
95
- level={2}
96
- tag="h3"
97
- text={`Clones (${instance.state.cloning.clones.length})`}
98
- rightContent={
99
- <>
100
- <Button
101
- theme="primary"
102
- onClick={goToCloneAddPage}
103
- isDisabled={!canCreateClone}
104
- isLoading={isLoadingSnapshots}
105
- >
106
- Create clone
107
- </Button>
108
-
109
- {!hasSnapshots && (
110
- <Tooltip content="No snapshots">
111
- <InfoIcon className={classes.infoIcon} />
112
- </Tooltip>
113
- )}
114
- </>
115
- }
116
- />
117
-
118
- <ClonesList
119
- clones={
120
- isShortList
121
- ? instance.state.cloning.clones.slice(0, SHORT_LIST_SIZE)
122
- : instance.state.cloning.clones
123
- }
124
- isDisabled={stores.main.isDisabledInstance}
125
- emptyStubText="This instance has no active clones"
126
- />
127
-
128
- {showListSizeButton && (
129
- <Button className={classes.listSizeButton} onClick={toggleListSize}>
130
- {isShortList ? 'Show more' : 'Show less'}
131
- </Button>
132
- )}
133
- </div>
134
- )
135
- })