@postgres.ai/shared 3.5.1-pr-1027.0 → 4.0.0-pr-1028.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 (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
@@ -0,0 +1,3 @@
1
+ import { createStrictContext } from '@postgres.ai/shared/utils/react';
2
+ export const { useStrictContext: useHost, Provider: HostProvider } = createStrictContext();
3
+ export const { useStrictContext: useStores, Provider: StoresProvider } = createStrictContext();
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ import { Host } from './context';
3
+ declare type Props = Host & {
4
+ isPlatform?: boolean;
5
+ };
6
+ export declare const BranchesPage: ((props: Props) => JSX.Element) & {
7
+ displayName: string;
8
+ };
9
+ export {};
@@ -0,0 +1,172 @@
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 { useEffect, useState } from 'react';
9
+ import { useHistory } from 'react-router';
10
+ import { observer } from 'mobx-react-lite';
11
+ import copyToClipboard from 'copy-to-clipboard';
12
+ import { makeStyles, Button, TextField, IconButton, Table, TableHead, TableRow, TableBody, } from '@material-ui/core';
13
+ import { ErrorStub } from '@postgres.ai/shared/components/ErrorStub';
14
+ import { PageSpinner } from '@postgres.ai/shared/components/PageSpinner';
15
+ import { SectionTitle } from '@postgres.ai/shared/components/SectionTitle';
16
+ import { Spinner } from '@postgres.ai/shared/components/Spinner';
17
+ import { Tooltip } from '@postgres.ai/shared/components/Tooltip';
18
+ import { icons } from '@postgres.ai/shared/styles/icons';
19
+ import { styles } from '@postgres.ai/shared/styles/styles';
20
+ import { DeleteBranchModal } from '@postgres.ai/shared/pages/Branches/components/Modals/DeleteBranchModal';
21
+ import { HorizontalScrollContainer } from '@postgres.ai/shared/components/HorizontalScrollContainer';
22
+ import { generateSnapshotPageId } from '@postgres.ai/shared/pages/Instance/Snapshots/utils';
23
+ import { SyntaxHighlight } from '@postgres.ai/shared/components/SyntaxHighlight';
24
+ import { getCliBranchListCommand } from '@postgres.ai/shared/pages/CreateBranch/utils';
25
+ import { TableBodyCell, TableBodyCellMenu, TableHeaderCell, } from '@postgres.ai/shared/components/Table';
26
+ import { useCreatedStores } from './useCreatedStores';
27
+ import { InstanceTabs, TABS_INDEX } from "../../Instance/Tabs";
28
+ const useStyles = makeStyles(() => ({
29
+ wrapper: {
30
+ display: 'flex',
31
+ gap: '60px',
32
+ maxWidth: '100%',
33
+ fontSize: '14px',
34
+ marginTop: '20px',
35
+ '@media (max-width: 1300px)': {
36
+ flexDirection: 'column',
37
+ gap: '20px',
38
+ },
39
+ },
40
+ marginTop: {
41
+ marginTop: '16px',
42
+ },
43
+ title: {
44
+ marginTop: '8px',
45
+ lineHeight: '26px'
46
+ },
47
+ container: {
48
+ maxWidth: '100%',
49
+ flex: '1 1 0',
50
+ minWidth: 0,
51
+ '& p,span': {
52
+ fontSize: 14,
53
+ },
54
+ },
55
+ snippetContainer: {
56
+ flex: '1 1 0',
57
+ minWidth: 0,
58
+ boxShadow: 'rgba(0, 0, 0, 0.1) 0px 4px 12px',
59
+ padding: '10px 20px 10px 20px',
60
+ height: 'max-content',
61
+ borderRadius: '4px',
62
+ },
63
+ actions: {
64
+ display: 'flex',
65
+ marginRight: '-16px',
66
+ },
67
+ spinner: {
68
+ marginLeft: '8px',
69
+ },
70
+ actionButton: {
71
+ marginRight: '16px',
72
+ },
73
+ summary: {
74
+ marginTop: 20,
75
+ },
76
+ text: {
77
+ marginTop: '4px',
78
+ },
79
+ cliText: {
80
+ marginTop: '8px',
81
+ },
82
+ paramTitle: {
83
+ display: 'inline-block',
84
+ width: 200,
85
+ },
86
+ copyFieldContainer: {
87
+ position: 'relative',
88
+ display: 'block',
89
+ maxWidth: 525,
90
+ width: '100%',
91
+ },
92
+ textField: {
93
+ ...styles.inputField,
94
+ 'max-width': 525,
95
+ display: 'inline-block',
96
+ '& .MuiOutlinedInput-input': {
97
+ paddingRight: '32px!important',
98
+ },
99
+ },
100
+ tableContainer: {
101
+ position: 'relative',
102
+ maxWidth: 525,
103
+ width: '100%',
104
+ },
105
+ copyButton: {
106
+ position: 'absolute',
107
+ top: 16,
108
+ right: 0,
109
+ zIndex: 100,
110
+ width: 32,
111
+ height: 32,
112
+ padding: 8,
113
+ },
114
+ pointerCursor: {
115
+ cursor: 'pointer',
116
+ },
117
+ }), { index: 1 });
118
+ export const BranchesPage = observer((props) => {
119
+ const classes = useStyles();
120
+ const history = useHistory();
121
+ const stores = useCreatedStores(props);
122
+ const [isOpenDestroyModal, setIsOpenDestroyModal] = useState(false);
123
+ const { branch, snapshotList, deleteBranch, reload, load, isReloading, isBranchesLoading, getBranchesError, snapshotListError, getBranchError, } = stores.main;
124
+ const hasBranchError = getBranchesError || getBranchError || snapshotListError;
125
+ const branchLogLength = snapshotList === null || snapshotList === void 0 ? void 0 : snapshotList.reduce((acc, snapshot) => {
126
+ var _a;
127
+ if ((snapshot === null || snapshot === void 0 ? void 0 : snapshot.branch) !== null) {
128
+ return acc + ((_a = snapshot.branch) === null || _a === void 0 ? void 0 : _a.length);
129
+ }
130
+ else {
131
+ return acc;
132
+ }
133
+ }, 0);
134
+ const headRendered = (_jsxs(_Fragment, { children: [_jsx("style", { children: 'p { margin: 0;}' }), props.elements.breadcrumbs, _jsx(SectionTitle, { className: classes.title, tag: "h1", level: 1, text: `Branch ${props.branchId}`, children: _jsx(InstanceTabs, { tab: TABS_INDEX.BRANCHES, isPlatform: props.isPlatform, instanceId: props.instanceId, hasLogs: props.api.initWS !== undefined }) })] }));
135
+ useEffect(() => {
136
+ load(props.branchId, props.instanceId);
137
+ }, []);
138
+ if (isBranchesLoading)
139
+ return _jsx(PageSpinner, {});
140
+ if (hasBranchError) {
141
+ return (_jsxs(_Fragment, { children: [headRendered, _jsx(ErrorStub, { title: (getBranchesError === null || getBranchesError === void 0 ? void 0 : getBranchesError.title) ||
142
+ (getBranchError === null || getBranchError === void 0 ? void 0 : getBranchError.title) ||
143
+ (snapshotListError === null || snapshotListError === void 0 ? void 0 : snapshotListError.title), message: (getBranchesError === null || getBranchesError === void 0 ? void 0 : getBranchesError.message) ||
144
+ (getBranchError === null || getBranchError === void 0 ? void 0 : getBranchError.message) ||
145
+ (snapshotListError === null || snapshotListError === void 0 ? void 0 : snapshotListError.message), className: classes.marginTop })] }));
146
+ }
147
+ return (_jsxs(_Fragment, { children: [headRendered, _jsxs("div", { className: classes.wrapper, children: [_jsxs("div", { className: classes.container, children: [_jsxs("div", { className: classes.actions, children: [_jsx(Button, { variant: "contained", color: "primary", onClick: () => history.push(props.routes.createClone(props.branchId)), disabled: isReloading, title: 'Create clone', className: classes.actionButton, children: "Create clone" }), _jsx(Button, { variant: "contained", color: "primary", onClick: () => setIsOpenDestroyModal(true), disabled: isReloading, title: 'Delete this branch', className: classes.actionButton, children: "Delete branch" }), _jsxs(Button, { variant: "outlined", color: "secondary", onClick: () => reload(props.branchId, props.instanceId), disabled: isReloading, title: 'Refresh branch information', className: classes.actionButton, children: ["Reload info", isReloading && _jsx(Spinner, { size: "sm", className: classes.spinner })] })] }), _jsx("br", {}), _jsxs("div", { children: [_jsxs("div", { children: [_jsxs("p", { children: [_jsx("strong", { children: "Data state at" }), "\u00A0", _jsx(Tooltip, { content: _jsxs(_Fragment, { children: [_jsx("strong", { children: "Data state time" }), " is a time at which data is\u00A0 recovered for this branch."] }), children: icons.infoIcon })] }), _jsx("p", { className: classes.text, children: (branch === null || branch === void 0 ? void 0 : branch.dataStateAt) || '-' })] }), _jsxs("div", { className: classes.summary, children: [_jsxs("p", { children: [_jsx("strong", { children: "Summary" }), "\u00A0"] }), _jsxs("p", { className: classes.text, children: [_jsx("span", { className: classes.paramTitle, children: "Branch name:" }), branch === null || branch === void 0 ? void 0 : branch.name] }), _jsxs("p", { className: classes.text, children: [_jsx("span", { className: classes.paramTitle, children: "Parent branch:" }), branch === null || branch === void 0 ? void 0 : branch.parent] })] }), _jsx("br", {}), _jsx("p", { children: _jsx("strong", { children: "Snapshot info" }) }), _jsxs("div", { className: classes.copyFieldContainer, children: [_jsx(TextField, { variant: "outlined", label: "Snapshot ID", value: branch === null || branch === void 0 ? void 0 : branch.snapshotID, className: classes.textField, margin: "normal", fullWidth: true, InputLabelProps: {
148
+ shrink: true,
149
+ style: styles.inputFieldLabel,
150
+ }, FormHelperTextProps: {
151
+ style: styles.inputFieldHelper,
152
+ } }), _jsx(IconButton, { className: classes.copyButton, "aria-label": "Copy", onClick: () => copyToClipboard(String(branch === null || branch === void 0 ? void 0 : branch.snapshotID)), children: icons.copyIcon })] }), _jsx("br", {}), Number(branchLogLength) > 0 && (_jsxs(_Fragment, { children: [_jsxs("strong", { children: ["Branch log (", branchLogLength, ")"] }), _jsx(HorizontalScrollContainer, { children: _jsxs(Table, { className: classes.tableContainer, children: [_jsx(TableHead, { children: _jsxs(TableRow, { children: [_jsx(TableHeaderCell, {}), _jsx(TableHeaderCell, { children: "Name" }), _jsx(TableHeaderCell, { children: "Snapshot ID" }), _jsx(TableHeaderCell, { children: "Data state at" }), _jsx(TableHeaderCell, { children: "Message" })] }) }), snapshotList === null || snapshotList === void 0 ? void 0 : snapshotList.map((snapshot, id) => {
153
+ var _a;
154
+ return (_jsx(TableBody, { children: (_a = snapshot === null || snapshot === void 0 ? void 0 : snapshot.branch) === null || _a === void 0 ? void 0 : _a.map((item, id) => {
155
+ var _a;
156
+ return (_jsxs(TableRow, { hover: true, className: classes.pointerCursor, onClick: () => generateSnapshotPageId(snapshot.id) &&
157
+ history.push(props.routes.snapshot(generateSnapshotPageId(snapshot.id) || '')), children: [_jsx(TableBodyCellMenu, { actions: [
158
+ {
159
+ name: 'Copy branch name',
160
+ onClick: () => copyToClipboard(item),
161
+ },
162
+ {
163
+ name: 'Copy snapshot ID',
164
+ onClick: () => copyToClipboard(snapshot.id || ''),
165
+ },
166
+ ] }), _jsx(TableBodyCell, { children: item }), _jsx(TableBodyCell, { children: snapshot.id || '-' }), _jsx(TableBodyCell, { children: snapshot.dataStateAt || '-' }), _jsx(TableBodyCell, { children: (_a = snapshot.message) !== null && _a !== void 0 ? _a : '-' })] }, id));
167
+ }) }, id));
168
+ })] }) })] }))] })] }), _jsxs("div", { className: classes.snippetContainer, children: [_jsx(SectionTitle, { className: classes.marginTop, tag: "h2", level: 2, text: 'Delete branch using CLI' }), _jsx("p", { className: classes.cliText, children: "You can delete this branch using CLI. To do this, run the command below:" }), _jsx(SyntaxHighlight, { content: `dblab branch delete ${props.branchId}` }), _jsx(SectionTitle, { className: classes.marginTop, tag: "h2", level: 2, text: 'Get branches using CLI' }), _jsx("p", { className: classes.marginTop, children: "To list all branches using CLI, copy and paste it into your terminal." }), _jsx(SyntaxHighlight, { content: getCliBranchListCommand() }), _jsx(SectionTitle, { className: classes.marginTop, tag: "h2", level: 2, text: 'Get snapshots for this branch using CLI' }), _jsx("p", { className: classes.cliText, children: "You can get a list of snapshots for this branch using CLI. To do this, run the command below:" }), _jsx(SyntaxHighlight, { content: `dblab branch log ${props.branchId}` })] }), _jsx(DeleteBranchModal, { isOpen: isOpenDestroyModal, onClose: () => setIsOpenDestroyModal(false), deleteBranch: deleteBranch, branchName: props.branchId, instanceId: props.instanceId, afterSubmitClick: () => {
169
+ stores.main.reload(props.branchId, props.instanceId);
170
+ history.push(props.routes.branches());
171
+ } })] })] }));
172
+ });
@@ -0,0 +1,37 @@
1
+ import { GetBranches } from '@postgres.ai/shared/types/api/endpoints/getBranches';
2
+ import { Branch } from '@postgres.ai/shared/types/api/endpoints/getBranches';
3
+ import { DeleteBranch } from '@postgres.ai/shared/types/api/endpoints/deleteBranch';
4
+ import { SnapshotList, GetSnapshotList } from '@postgres.ai/shared/types/api/endpoints/getSnapshotList';
5
+ import { InitWS } from '@postgres.ai/shared/types/api/endpoints/initWS';
6
+ declare type Error = {
7
+ title?: string;
8
+ message: string;
9
+ };
10
+ export declare type Api = {
11
+ getBranches: GetBranches;
12
+ deleteBranch: DeleteBranch;
13
+ getSnapshotList: GetSnapshotList;
14
+ initWS: InitWS;
15
+ };
16
+ export declare class MainStore {
17
+ getBranchError: Error | null;
18
+ snapshotListError: Error | null;
19
+ getBranchesError: Error | null;
20
+ isReloading: boolean;
21
+ isBranchesLoading: boolean;
22
+ branches: Branch[] | null;
23
+ branch: Branch | null;
24
+ snapshotList: SnapshotList[] | null;
25
+ private readonly api;
26
+ constructor(api: Api);
27
+ load: (branchId: string, instanceId: string) => Promise<void>;
28
+ reload: (branchId: string, instanceId: string) => Promise<void>;
29
+ getBranches: (branchId: string, instanceId: string) => Promise<Branch[] | null | undefined>;
30
+ getBranch: (branchId: string, instanceId: string) => Promise<boolean>;
31
+ deleteBranch: (branchName: string, instanceId: string) => Promise<{
32
+ response: Response | null;
33
+ error: globalThis.Error | null;
34
+ } | undefined>;
35
+ getSnapshotList: (branchName: string, instanceId: string) => Promise<SnapshotList[] | null | undefined>;
36
+ }
37
+ export {};
@@ -0,0 +1,90 @@
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 MainStore {
9
+ constructor(api) {
10
+ this.getBranchError = null;
11
+ this.snapshotListError = null;
12
+ this.getBranchesError = null;
13
+ this.isReloading = false;
14
+ this.isBranchesLoading = false;
15
+ this.branches = null;
16
+ this.branch = null;
17
+ this.snapshotList = null;
18
+ this.load = async (branchId, instanceId) => {
19
+ if (!branchId)
20
+ return;
21
+ this.isBranchesLoading = true;
22
+ await this.getBranches(branchId, instanceId);
23
+ };
24
+ this.reload = async (branchId, instanceId) => {
25
+ if (!branchId)
26
+ return;
27
+ this.isReloading = true;
28
+ await this.getBranches(branchId, instanceId);
29
+ this.isReloading = false;
30
+ };
31
+ this.getBranches = async (branchId, instanceId) => {
32
+ if (!this.api.getBranches)
33
+ return;
34
+ const { response, error } = await this.api.getBranches(instanceId);
35
+ if (error) {
36
+ this.isBranchesLoading = false;
37
+ this.getBranchesError = await error.json().then((err) => err);
38
+ }
39
+ if (response) {
40
+ this.branches = response;
41
+ this.getBranch(branchId, instanceId);
42
+ }
43
+ return response;
44
+ };
45
+ this.getBranch = async (branchId, instanceId) => {
46
+ var _a;
47
+ const currentBranch = (_a = this.branches) === null || _a === void 0 ? void 0 : _a.filter((s) => {
48
+ return s.name === branchId;
49
+ });
50
+ if (currentBranch && (currentBranch === null || currentBranch === void 0 ? void 0 : currentBranch.length) > 0) {
51
+ this.branch = currentBranch[0];
52
+ this.getSnapshotList(currentBranch[0].name, instanceId);
53
+ }
54
+ else {
55
+ this.getBranchError = {
56
+ title: 'Error',
57
+ message: `Branch "${branchId}" not found`,
58
+ };
59
+ this.isBranchesLoading = false;
60
+ }
61
+ return !!currentBranch;
62
+ };
63
+ this.deleteBranch = async (branchName, instanceId) => {
64
+ var _a;
65
+ if (!branchName)
66
+ return;
67
+ const { response, error } = await this.api.deleteBranch(branchName, instanceId);
68
+ if (response) {
69
+ this.branches =
70
+ ((_a = this.branches) === null || _a === void 0 ? void 0 : _a.filter((branch) => branch.name !== branchName)) || [];
71
+ }
72
+ return { response, error };
73
+ };
74
+ this.getSnapshotList = async (branchName, instanceId) => {
75
+ if (!this.api.getSnapshotList)
76
+ return;
77
+ const { response, error } = await this.api.getSnapshotList(branchName, instanceId);
78
+ this.isBranchesLoading = false;
79
+ if (error) {
80
+ this.snapshotListError = await error.json().then((err) => err);
81
+ }
82
+ if (response) {
83
+ this.snapshotList = response;
84
+ }
85
+ return response;
86
+ };
87
+ this.api = api;
88
+ makeAutoObservable(this);
89
+ }
90
+ }
@@ -0,0 +1,6 @@
1
+ import { MainStore } from './stores/Main';
2
+ import { Host } from './context';
3
+ export declare const useCreatedStores: (host: Host) => {
4
+ main: MainStore;
5
+ };
6
+ export declare type Stores = ReturnType<typeof useCreatedStores>;
@@ -0,0 +1,5 @@
1
+ import { useMemo } from 'react';
2
+ import { MainStore } from './stores/Main';
3
+ export const useCreatedStores = (host) => ({
4
+ main: useMemo(() => new MainStore(host.api), []),
5
+ });
@@ -0,0 +1,10 @@
1
+ /// <reference types="react" />
2
+ import { Branch } from '@postgres.ai/shared/types/api/endpoints/getBranches';
3
+ import { DeleteBranch } from '@postgres.ai/shared/types/api/endpoints/deleteBranch';
4
+ export declare const BranchesTable: ({ branches, emptyTableText, deleteBranch, branchesRoute, reloadBranches, }: {
5
+ branches: Branch[];
6
+ emptyTableText: string;
7
+ deleteBranch: DeleteBranch;
8
+ branchesRoute: string;
9
+ reloadBranches: () => void;
10
+ }) => JSX.Element;
@@ -0,0 +1,107 @@
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 cn from 'classnames';
9
+ import { useEffect, useState } from 'react';
10
+ import copy from 'copy-to-clipboard';
11
+ import { makeStyles } from '@material-ui/core';
12
+ import { useHistory } from 'react-router-dom';
13
+ import { formatDistanceToNowStrict } from 'date-fns';
14
+ import { isValidDate } from '@postgres.ai/shared/utils/date';
15
+ import { ArrowDropDownIcon } from '@postgres.ai/shared/icons/ArrowDropDown';
16
+ import { HorizontalScrollContainer } from '@postgres.ai/shared/components/HorizontalScrollContainer';
17
+ import { useHost } from '@postgres.ai/shared/pages/Instance/context';
18
+ import { Table, TableHead, TableRow, TableBody, TableHeaderCell, TableBodyCell, TableBodyCellMenu, } from '@postgres.ai/shared/components/Table';
19
+ import { DeleteBranchModal } from '../Modals/DeleteBranchModal';
20
+ const useStyles = makeStyles({
21
+ cellContentCentered: {
22
+ display: 'flex',
23
+ alignItems: 'center',
24
+ },
25
+ pointerCursor: {
26
+ cursor: 'pointer',
27
+ },
28
+ sortIcon: {
29
+ marginLeft: '8px',
30
+ width: '10px',
31
+ },
32
+ interactiveRow: {
33
+ cursor: 'pointer',
34
+ },
35
+ verticalCentered: {
36
+ display: 'flex',
37
+ alignItems: 'center',
38
+ },
39
+ marginTop: {
40
+ marginTop: '16px',
41
+ },
42
+ sortIconUp: {
43
+ transform: 'rotate(180deg)',
44
+ },
45
+ }, { index: 1 });
46
+ export const BranchesTable = ({ branches, emptyTableText, deleteBranch, branchesRoute, reloadBranches, }) => {
47
+ var _a;
48
+ const host = useHost();
49
+ const history = useHistory();
50
+ const classes = useStyles();
51
+ const [state, setState] = useState({
52
+ sortByParent: 'desc',
53
+ branches: [],
54
+ });
55
+ const [branchId, setBranchId] = useState('');
56
+ const [isOpenDestroyModal, setIsOpenDestroyModal] = useState(false);
57
+ const handlesortByParent = () => {
58
+ const sortByParent = state.sortByParent === 'desc' ? 'asc' : 'desc';
59
+ const sortedBranches = [...state.branches].sort((a, b) => {
60
+ if (sortByParent === 'asc') {
61
+ return a.parent.localeCompare(b.parent);
62
+ }
63
+ else {
64
+ return b.parent.localeCompare(a.parent);
65
+ }
66
+ });
67
+ setState({
68
+ sortByParent,
69
+ branches: sortedBranches,
70
+ });
71
+ };
72
+ useEffect(() => {
73
+ setState({
74
+ sortByParent: 'desc',
75
+ branches: branches !== null && branches !== void 0 ? branches : [],
76
+ });
77
+ }, [branches]);
78
+ if (!state.branches.length) {
79
+ return _jsx("p", { className: classes.marginTop, children: emptyTableText });
80
+ }
81
+ return (_jsx(HorizontalScrollContainer, { children: _jsxs(Table, { children: [_jsx(TableHead, { children: _jsxs(TableRow, { children: [_jsx(TableHeaderCell, {}), _jsx(TableHeaderCell, { children: "Branch" }), _jsx(TableHeaderCell, { children: _jsxs("div", { onClick: handlesortByParent, className: cn(classes.interactiveRow, classes.verticalCentered), children: ["Parent", _jsx(ArrowDropDownIcon, { className: cn(state.sortByParent === 'asc' && classes.sortIconUp, classes.sortIcon) })] }) }), _jsx(TableHeaderCell, { children: "Data state time" }), _jsx(TableHeaderCell, { children: "Latest Snapshot ID" }), _jsx(TableHeaderCell, { children: "Number of snapshots" })] }) }), _jsx(TableBody, { children: (_a = state.branches) === null || _a === void 0 ? void 0 : _a.map((branch) => {
82
+ const branchPagePath = host.routes.branch(branch.name);
83
+ return (_jsxs(TableRow, { hover: true, onClick: () => history.push(branchPagePath), className: classes.pointerCursor, children: [_jsx(TableBodyCellMenu, { actions: [
84
+ {
85
+ name: 'Copy snapshot ID',
86
+ onClick: () => copy(branch.snapshotID),
87
+ },
88
+ {
89
+ name: 'Delete branch',
90
+ onClick: () => {
91
+ setBranchId(branch.name);
92
+ setIsOpenDestroyModal(true);
93
+ },
94
+ },
95
+ ] }), _jsx(TableBodyCell, { children: branch.name }), _jsx(TableBodyCell, { children: branch.parent }), _jsxs(TableBodyCell, { children: [branch.dataStateAt, " (", isValidDate(new Date(branch.dataStateAt))
96
+ ? formatDistanceToNowStrict(new Date(branch.dataStateAt), {
97
+ addSuffix: true,
98
+ })
99
+ : '-', ")"] }), _jsx(TableBodyCell, { children: branch.snapshotID }), _jsx(TableBodyCell, { children: branch.numSnapshots })] }, branch.name));
100
+ }) }), _jsx(DeleteBranchModal, { isOpen: isOpenDestroyModal, onClose: () => {
101
+ setIsOpenDestroyModal(false);
102
+ setBranchId('');
103
+ }, deleteBranch: deleteBranch, branchName: branchId, instanceId: host.instanceId, afterSubmitClick: () => {
104
+ reloadBranches();
105
+ history.push(branchesRoute);
106
+ } })] }) }));
107
+ };
@@ -0,0 +1,11 @@
1
+ /// <reference types="react" />
2
+ import { ModalProps } from '@postgres.ai/shared/pages/Branches/components/Modals/types';
3
+ import { DeleteBranch } from '@postgres.ai/shared/types/api/endpoints/deleteBranch';
4
+ interface DeleteBranchModalProps extends ModalProps {
5
+ deleteBranch: DeleteBranch;
6
+ branchName: string;
7
+ instanceId: string;
8
+ afterSubmitClick: () => void;
9
+ }
10
+ export declare const DeleteBranchModal: ({ isOpen, onClose, deleteBranch, branchName, instanceId, afterSubmitClick, }: DeleteBranchModalProps) => JSX.Element;
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 { makeStyles } from '@material-ui/core';
10
+ import { Modal } from '@postgres.ai/shared/components/Modal';
11
+ import { SimpleModalControls } from '@postgres.ai/shared/components/SimpleModalControls';
12
+ import { ImportantText } from '@postgres.ai/shared/components/ImportantText';
13
+ import { Text } from '@postgres.ai/shared/components/Text';
14
+ const useStyles = makeStyles({
15
+ errorMessage: {
16
+ color: 'red',
17
+ marginTop: '10px',
18
+ },
19
+ }, { index: 1 });
20
+ export const DeleteBranchModal = ({ isOpen, onClose, deleteBranch, branchName, instanceId, afterSubmitClick, }) => {
21
+ const classes = useStyles();
22
+ const [deleteError, setDeleteError] = useState(null);
23
+ const handleDelete = async () => {
24
+ var _a;
25
+ const deleteRes = await deleteBranch(branchName, instanceId);
26
+ if (deleteRes === null || deleteRes === void 0 ? void 0 : deleteRes.error) {
27
+ setDeleteError((_a = deleteRes.error) === null || _a === void 0 ? void 0 : _a.message);
28
+ }
29
+ else {
30
+ afterSubmitClick();
31
+ }
32
+ };
33
+ const handleClose = () => {
34
+ setDeleteError(null);
35
+ onClose();
36
+ };
37
+ return (_jsxs(Modal, { title: "Confirmation", onClose: handleClose, isOpen: isOpen, size: "xs", children: [_jsxs(Text, { children: ["Are you sure you want to delete branch", ' ', _jsx(ImportantText, { children: branchName }), "? This action cannot be undone."] }), deleteError && _jsx("p", { className: classes.errorMessage, children: deleteError }), _jsx(SimpleModalControls, { items: [
38
+ {
39
+ text: 'Cancel',
40
+ onClick: handleClose,
41
+ },
42
+ {
43
+ text: 'Delete branch',
44
+ variant: 'primary',
45
+ onClick: handleDelete,
46
+ isDisabled: branchName === 'main',
47
+ },
48
+ ] })] }));
49
+ };
@@ -0,0 +1,4 @@
1
+ export interface ModalProps {
2
+ isOpen: boolean;
3
+ onClose: () => void;
4
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ interface BranchesProps {
3
+ instanceId: string;
4
+ }
5
+ export declare const Branches: React.FC<BranchesProps>;
6
+ export {};
@@ -0,0 +1,60 @@
1
+ import { Fragment as _Fragment, 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 { observer } from 'mobx-react-lite';
9
+ import { useHistory } from 'react-router';
10
+ import { makeStyles } from '@material-ui/core';
11
+ import { useEffect, useState } from 'react';
12
+ import { useStores, useHost } from '@postgres.ai/shared/pages/Instance/context';
13
+ import { Button } from '@postgres.ai/shared/components/Button2';
14
+ import { Spinner } from '@postgres.ai/shared/components/Spinner';
15
+ import { ErrorStub } from '@postgres.ai/shared/components/ErrorStub';
16
+ import { BranchesTable } from '@postgres.ai/shared/pages/Branches/components/BranchesTable';
17
+ import { SectionTitle } from '@postgres.ai/shared/components/SectionTitle';
18
+ import { Tooltip } from '@postgres.ai/shared/components/Tooltip';
19
+ import { InfoIcon } from '@postgres.ai/shared/icons/Info';
20
+ const useStyles = makeStyles({
21
+ container: {
22
+ marginTop: '16px',
23
+ },
24
+ infoIcon: {
25
+ height: '12px',
26
+ width: '12px',
27
+ marginLeft: '8px',
28
+ color: '#808080',
29
+ },
30
+ spinner: {
31
+ position: 'absolute',
32
+ right: '50%',
33
+ transform: 'translate(-50%, -50%)',
34
+ },
35
+ }, { index: 1 });
36
+ export const Branches = observer(({ instanceId }) => {
37
+ const host = useHost();
38
+ const stores = useStores();
39
+ const classes = useStyles();
40
+ const history = useHistory();
41
+ const [branches, setBranches] = useState([]);
42
+ const [isLoading, setIsLoading] = useState(true);
43
+ const { instance, getBranches, isBranchesLoading, getBranchesError, deleteBranch, } = stores.main;
44
+ const goToBranchAddPage = () => history.push(host.routes.createBranch());
45
+ const loadBranches = () => {
46
+ getBranches(instanceId)
47
+ .then((response) => {
48
+ response && setBranches(response);
49
+ })
50
+ .finally(() => setIsLoading(false));
51
+ };
52
+ useEffect(() => {
53
+ loadBranches();
54
+ }, []);
55
+ if (!instance && !isBranchesLoading)
56
+ return _jsx(_Fragment, {});
57
+ if (getBranchesError)
58
+ return (_jsx(ErrorStub, { title: getBranchesError === null || getBranchesError === void 0 ? void 0 : getBranchesError.title, message: getBranchesError === null || getBranchesError === void 0 ? void 0 : getBranchesError.message }));
59
+ return (_jsx("div", { className: classes.container, children: isBranchesLoading || isLoading ? (_jsx(Spinner, { size: "lg", className: classes.spinner })) : (_jsxs(_Fragment, { children: [_jsx(SectionTitle, { level: 2, tag: "h2", text: `Branches (${(branches === null || branches === void 0 ? void 0 : branches.length) || 0})`, rightContent: _jsxs(_Fragment, { children: [_jsx(Button, { theme: "primary", isDisabled: !branches.length, onClick: goToBranchAddPage, children: "Create branch" }), !branches.length && (_jsx(Tooltip, { content: "No existing branch", children: _jsx("div", { style: { display: 'flex' }, children: _jsx(InfoIcon, { className: classes.infoIcon }) }) }))] }) }), _jsx(BranchesTable, { branches: branches, branchesRoute: host.routes.branches(), reloadBranches: loadBranches, deleteBranch: deleteBranch, emptyTableText: "This instance has no active branches." })] })) }));
60
+ });
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import { CloneDto } from '@postgres.ai/shared/types/api/entities/clone';
3
+ declare type Props = {
4
+ rawClone: CloneDto;
5
+ className?: string;
6
+ };
7
+ export declare const Status: React.MemoExoticComponent<(props: Props) => JSX.Element>;
8
+ export {};
@@ -0,0 +1,38 @@
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 React from 'react';
9
+ import { makeStyles } from '@material-ui/core';
10
+ import clsx from 'clsx';
11
+ import { formatCloneDto, } from '@postgres.ai/shared/types/api/entities/clone';
12
+ import { Status as StatusBase } from '@postgres.ai/shared/components/Status';
13
+ import { FormattedText } from '@postgres.ai/shared/components/FormattedText';
14
+ import { getCloneStatusType, getCloneStatusText, } from '@postgres.ai/shared/utils/clone';
15
+ const useStyles = makeStyles({
16
+ root: {
17
+ marginTop: '2px',
18
+ },
19
+ status: {
20
+ fontWeight: 500,
21
+ },
22
+ message: {
23
+ margin: '4px 0 0 0',
24
+ },
25
+ errorMessage: {
26
+ marginTop: '8px',
27
+ },
28
+ }, { index: 1 });
29
+ export const Status = React.memo((props) => {
30
+ const { rawClone, className } = props;
31
+ const classes = useStyles();
32
+ const clone = formatCloneDto(rawClone);
33
+ const { code, message } = clone.status;
34
+ const statusType = getCloneStatusType(code);
35
+ const statusText = getCloneStatusText(code);
36
+ const isError = statusType === 'error';
37
+ return (_jsxs("div", { className: clsx(classes.root, className), children: [_jsx(StatusBase, { type: statusType, className: classes.status, children: statusText }), !isError && _jsx("p", { className: classes.message, children: message }), isError && (_jsx(FormattedText, { value: message, className: classes.errorMessage }))] }));
38
+ });