@dovetail-v2/refine 0.0.63-pod-exec.0 → 0.0.64
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.
- package/dist/{MonacoYamlDiffEditor-79a8df0a.js → MonacoYamlDiffEditor-c863e3f0.js} +1 -1
- package/dist/{index-f192f242.js → index-7523291c.js} +5948 -14736
- package/dist/refine.js +179 -160
- package/dist/refine.umd.cjs +5721 -14509
- package/dist/style.css +14 -232
- package/lib/src/App.js +91 -0
- package/lib/src/Dovetail.js +45 -0
- package/lib/src/components/Breadcrumb/index.js +20 -0
- package/lib/src/components/ConditionsTable/ConditionsTable.js +56 -0
- package/lib/src/components/ConditionsTable/index.js +1 -0
- package/lib/src/components/CreateButton/index.js +10 -0
- package/lib/src/components/CronJobDropdown/index.js +26 -0
- package/lib/src/components/CronjobJobsTable/index.js +49 -0
- package/lib/src/components/DeleteButton/index.js +13 -0
- package/lib/src/components/DeleteManyButton/index.js +16 -0
- package/lib/src/components/DrawerShow/DrawerShow.js +13 -0
- package/lib/src/components/DrawerShow/index.js +1 -0
- package/lib/src/components/EditButton/index.js +13 -0
- package/lib/src/components/EditField/index.js +47 -0
- package/lib/src/components/ErrorContent/index.js +36 -0
- package/lib/src/components/EventsTable/EventsTable.js +59 -0
- package/lib/src/components/EventsTable/index.js +1 -0
- package/lib/src/components/Form/FormModal.d.ts +0 -1
- package/lib/src/components/Form/KeyValueListWidget.js +56 -0
- package/lib/src/components/Form/MetadataForm.js +9 -0
- package/lib/src/components/Form/NameInputWidget.js +50 -0
- package/lib/src/components/Form/NamespaceSelectWidget.js +21 -0
- package/lib/src/components/Form/index.js +4 -0
- package/lib/src/components/Form/type.d.ts +4 -3
- package/lib/src/components/Form/widget.js +1 -0
- package/lib/src/components/FormErrorAlert/index.js +8 -0
- package/lib/src/components/FormLayout/index.js +21 -0
- package/lib/src/components/FormModal/index.js +51 -0
- package/lib/src/components/ImageNames/index.js +14 -0
- package/lib/src/components/IngressRulesComponent/index.js +11 -0
- package/lib/src/components/IngressRulesTable/IngressRulesTable.js +51 -0
- package/lib/src/components/IngressRulesTable/index.js +1 -0
- package/lib/src/components/K8sDropdown/index.d.ts +1 -1
- package/lib/src/components/K8sDropdown/index.js +31 -0
- package/lib/src/components/KeyValue/KeyValue.js +27 -0
- package/lib/src/components/KeyValue/index.js +1 -0
- package/lib/src/components/KeyValueData/index.js +50 -0
- package/lib/src/components/Layout/index.js +39 -0
- package/lib/src/components/ListPage/index.js +25 -0
- package/lib/src/components/Menu/index.js +36 -0
- package/lib/src/components/NamespacesFilter/index.js +34 -0
- package/lib/src/components/NetworkPolicyRulesTable/NetworkPolicyRulesTable.d.ts +1 -2
- package/lib/src/components/NetworkPolicyRulesTable/NetworkPolicyRulesTable.js +77 -0
- package/lib/src/components/NetworkPolicyRulesTable/index.js +1 -0
- package/lib/src/components/PageShow/PageShow.js +11 -0
- package/lib/src/components/PageShow/index.js +1 -0
- package/lib/src/components/PodContainersTable/PodContainersTable.js +78 -0
- package/lib/src/components/PodContainersTable/index.js +1 -0
- package/lib/src/components/PodLog/index.js +136 -0
- package/lib/src/components/ReferenceLink/index.js +17 -0
- package/lib/src/components/RefineForm/RefineFormContent.d.ts +10 -0
- package/lib/src/components/RefineForm/RefineFormModal.d.ts +8 -0
- package/lib/src/components/RefineForm/RefineFormPage.d.ts +7 -0
- package/lib/src/components/RefineForm/index.d.ts +3 -0
- package/lib/src/components/RefineForm/type.d.ts +20 -0
- package/lib/src/components/RefineForm/useRefineForm.d.ts +10 -0
- package/lib/src/components/ResourceCRUD/ResourceCRUD.js +15 -0
- package/lib/src/components/ResourceCRUD/create/index.js +13 -0
- package/lib/src/components/ResourceCRUD/index.js +4 -0
- package/lib/src/components/ResourceCRUD/list/index.js +19 -0
- package/lib/src/components/ResourceCRUD/show/index.js +6 -0
- package/lib/src/components/ResourceLink/index.d.ts +1 -1
- package/lib/src/components/ResourceLink/index.js +21 -0
- package/lib/src/components/ResourceUsageBar/index.js +81 -0
- package/lib/src/components/Separator/index.js +11 -0
- package/lib/src/components/ShowContent/ShowContent.js +157 -0
- package/lib/src/components/ShowContent/fields.d.ts +7 -1
- package/lib/src/components/ShowContent/fields.js +157 -0
- package/lib/src/components/ShowContent/groups.d.ts +2 -1
- package/lib/src/components/ShowContent/index.js +2 -0
- package/lib/src/components/StateTag/StateTag.js +22 -0
- package/lib/src/components/StateTag/index.js +1 -0
- package/lib/src/components/Table/ErrorContent.js +36 -0
- package/lib/src/components/Table/TableToolBar.js +14 -0
- package/lib/src/components/Table/TableWidgets.js +28 -0
- package/lib/src/components/Table/index.js +69 -0
- package/lib/src/components/Tags/index.js +22 -0
- package/lib/src/components/Time/index.js +14 -0
- package/lib/src/components/ValueDisplay/index.d.ts +1 -1
- package/lib/src/components/WorkloadDropdown/index.js +24 -0
- package/lib/src/components/WorkloadPodsTable/WorkloadPodsTable.js +39 -0
- package/lib/src/components/WorkloadPodsTable/index.js +1 -0
- package/lib/src/components/WorkloadReplicas/index.js +50 -0
- package/lib/src/components/YamlEditor/MonacoYamlDiffEditor.js +34 -0
- package/lib/src/components/YamlEditor/MonacoYamlEditor.js +149 -0
- package/lib/src/components/YamlEditor/YamlEditorComponent.js +90 -0
- package/lib/src/components/YamlEditor/index.js +1 -0
- package/lib/src/components/YamlEditor/style.js +102 -0
- package/lib/src/components/YamlEditor/yaml.worker.js +1 -0
- package/lib/src/components/YamlForm/index.d.ts +0 -4
- package/lib/src/components/YamlForm/index.js +61 -0
- package/lib/src/components/index.d.ts +2 -1
- package/lib/src/components/index.js +38 -0
- package/lib/src/constants/index.js +2 -0
- package/lib/src/constants/k8s.d.ts +18 -0
- package/lib/src/constants/k8s.js +203 -0
- package/lib/src/constants/state.js +15 -0
- package/lib/src/contexts/component.js +3 -0
- package/lib/src/contexts/configs.js +3 -0
- package/lib/src/contexts/global-store.js +3 -0
- package/lib/src/contexts/index.js +3 -0
- package/lib/src/hooks/index.js +7 -0
- package/lib/src/hooks/useDeleteModal/index.js +1 -0
- package/lib/src/hooks/useDeleteModal/useDeleteManyModal.js +31 -0
- package/lib/src/hooks/useDeleteModal/useDeleteModal.js +38 -0
- package/lib/src/hooks/useDownloadYAML.js +10 -0
- package/lib/src/hooks/useEagleForm.d.ts +1 -2
- package/lib/src/hooks/useEagleForm.js +177 -0
- package/lib/src/hooks/useEagleTable/columns.d.ts +8 -1
- package/lib/src/hooks/useEagleTable/columns.js +246 -0
- package/lib/src/hooks/useEagleTable/index.js +2 -0
- package/lib/src/hooks/useEagleTable/useEagleTable.js +63 -0
- package/lib/src/hooks/useEdit.js +19 -0
- package/lib/src/hooks/useGlobalStore.js +5 -0
- package/lib/src/hooks/useK8sYamlEditor.js +37 -0
- package/lib/src/hooks/useOpenForm.js +43 -0
- package/lib/src/hooks/useSchema.js +37 -0
- package/lib/src/hooks/useSubmitForm.js +42 -0
- package/lib/src/i18n.d.ts +4 -2
- package/lib/src/i18n.js +19 -0
- package/lib/src/index.js +13 -0
- package/lib/src/locales/en-US/dovetail.json +18 -0
- package/lib/src/locales/en-US/index.d.ts +0 -1
- package/lib/src/locales/en-US/index.js +4 -0
- package/lib/src/locales/index.js +6 -0
- package/lib/src/locales/zh-CN/dovetail.json +91 -0
- package/lib/src/locales/zh-CN/index.d.ts +4 -1
- package/lib/src/locales/zh-CN/index.js +4 -0
- package/lib/src/main.js +12 -0
- package/lib/src/models/cronjob-model.js +32 -0
- package/lib/src/models/daemonset-model.js +17 -0
- package/lib/src/models/deployment-model.js +17 -0
- package/lib/src/models/event-model.js +11 -0
- package/lib/src/models/index.d.ts +4 -0
- package/lib/src/models/index.js +14 -0
- package/lib/src/models/ingress-model.js +24 -0
- package/lib/src/models/job-model.js +56 -0
- package/lib/src/models/network-policy-model.js +10 -0
- package/lib/src/models/node-model.d.ts +3 -0
- package/lib/src/models/pod-metrics-model.js +34 -0
- package/lib/src/models/pod-model.js +78 -0
- package/lib/src/models/resource-model.js +34 -0
- package/lib/src/models/server-instance-model.d.ts +10 -0
- package/lib/src/models/service-model.js +17 -0
- package/lib/src/models/statefulset-model.js +17 -0
- package/lib/src/models/storage-class.d.ts +3 -0
- package/lib/src/models/types/index.js +1 -0
- package/lib/src/models/types/metric.js +1 -0
- package/lib/src/models/workload-base-model.d.ts +2 -2
- package/lib/src/models/workload-base-model.js +22 -0
- package/lib/src/models/workload-model.js +51 -0
- package/lib/src/pages/configmaps/index.js +15 -0
- package/lib/src/pages/cronjobs/create/index.js +6 -0
- package/lib/src/pages/cronjobs/index.js +3 -0
- package/lib/src/pages/cronjobs/list/index.js +42 -0
- package/lib/src/pages/cronjobs/show/index.js +16 -0
- package/lib/src/pages/daemonsets/create/index.js +6 -0
- package/lib/src/pages/daemonsets/index.js +3 -0
- package/lib/src/pages/daemonsets/list/index.js +32 -0
- package/lib/src/pages/daemonsets/show/index.js +16 -0
- package/lib/src/pages/deployments/create/index.js +7 -0
- package/lib/src/pages/deployments/index.js +3 -0
- package/lib/src/pages/deployments/list/index.js +26 -0
- package/lib/src/pages/deployments/show/index.js +16 -0
- package/lib/src/pages/ingresses/index.js +26 -0
- package/lib/src/pages/jobs/index.js +34 -0
- package/lib/src/pages/networkPolicies/index.js +67 -0
- package/lib/src/pages/persistentvolumes/index.d.ts +19 -0
- package/lib/src/pages/pods/create/index.js +6 -0
- package/lib/src/pages/pods/index.js +3 -0
- package/lib/src/pages/pods/list/index.js +81 -0
- package/lib/src/pages/pods/show/index.js +54 -0
- package/lib/src/pages/secrets/index.js +15 -0
- package/lib/src/pages/services/index.js +26 -0
- package/lib/src/pages/statefulsets/create/index.js +6 -0
- package/lib/src/pages/statefulsets/index.js +3 -0
- package/lib/src/pages/statefulsets/list/index.js +26 -0
- package/lib/src/pages/statefulsets/show/index.js +16 -0
- package/lib/src/pages/storageclasses/index.d.ts +6 -5
- package/lib/src/plugins/index.js +3 -0
- package/lib/src/plugins/model-plugin.js +46 -0
- package/lib/src/plugins/relation-plugin.js +81 -0
- package/lib/src/plugins/type.js +1 -0
- package/lib/src/providers/index.js +1 -0
- package/lib/src/providers/router-provider/index.js +100 -0
- package/lib/src/types/index.js +1 -0
- package/lib/src/types/resource.d.ts +3 -1
- package/lib/src/types/resource.js +12 -0
- package/lib/src/utils/addId.js +8 -0
- package/lib/src/utils/download.js +9 -0
- package/lib/src/utils/error.js +53 -0
- package/lib/src/utils/form.js +9 -0
- package/lib/src/utils/k8s.js +6 -0
- package/lib/src/utils/labels.js +15 -0
- package/lib/src/utils/match-selector.js +12 -0
- package/lib/src/utils/openapi.js +33 -0
- package/lib/src/utils/schema.js +117 -0
- package/lib/src/utils/selector.js +12 -0
- package/lib/src/utils/string.js +6 -0
- package/lib/src/utils/time.js +46 -0
- package/lib/src/utils/unit.js +69 -0
- package/lib/src/utils/yaml.js +44 -0
- package/lib/vite.config.js +60 -0
- package/package.json +1 -6
- package/lib/src/components/ModalContextProvider/index.d.ts +0 -12
- package/lib/src/components/PodDropdown/index.d.ts +0 -9
- package/lib/src/components/PodShellModal/index.d.ts +0 -7
- package/lib/src/hooks/useModal.d.ts +0 -0
- package/lib/src/hooks/useNamespaceFilter.d.ts +0 -5
- package/lib/src/model/cronjob-model.d.ts +0 -9
- package/lib/src/model/index.d.ts +0 -6
- package/lib/src/model/job-model.d.ts +0 -10
- package/lib/src/model/pod-metrics-model.d.ts +0 -7
- package/lib/src/model/pod-model.d.ts +0 -15
- package/lib/src/model/resource-model.d.ts +0 -17
- package/lib/src/model/workload-model.d.ts +0 -17
- package/lib/src/pages/nodes/hooks/useNodeMetrics.d.ts +0 -17
- package/lib/src/pages/storageclasses/list/index.d.ts +0 -3
- package/lib/src/pages/storageclasses/show/index.d.ts +0 -3
- package/lib/src/types/metric.d.ts +0 -25
- package/lib/src/utils/shell.d.ts +0 -16
package/dist/style.css
CHANGED
|
@@ -30,9 +30,9 @@
|
|
|
30
30
|
.h11urhaw{margin-right:8px;line-height:18px;}
|
|
31
31
|
.e1i58tpl.ant-btn.ant-btn-link{height:18px;line-height:18px;font-size:12px;}
|
|
32
32
|
.s9agep2{height:100%;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;background:linear-gradient(180deg,#fff 0%,#edf0f7 100%);}.s9agep2 .ant-row{margin-right:0 !important;}
|
|
33
|
-
.bo89gfi{color:rgba(0,21,64,0.3);line-height:18px;cursor:pointer;display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-align-self:flex-start;-ms-flex-item-align:start;align-self:flex-start;}.bo89gfi:hover{color:#
|
|
33
|
+
.bo89gfi{color:rgba(0,21,64,0.3);line-height:18px;cursor:pointer;display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-align-self:flex-start;-ms-flex-item-align:start;align-self:flex-start;}.bo89gfi:hover{color:#0080ff;}
|
|
34
34
|
.t1ohe42f{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;padding:16px 24px 8px 24px;background-color:#fff;}
|
|
35
|
-
.nqm4qz0{color:#
|
|
35
|
+
.nqm4qz0{color:#00122e;margin-right:8px;}
|
|
36
36
|
.ticl0qc{-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;width:100%;}
|
|
37
37
|
.so9uwk1{width:100%;}
|
|
38
38
|
.ge26ou0{padding:12px 16px;padding-bottom:4px;border-radius:8px;border:1px solid rgba(211,218,235,0.6);box-shadow: 0px 0px 2.003px 0px rgba(107,125,153,0.15), 0px 0px 16px 0px rgba(107,125,153,0.08);background-color:#fff;margin:0 24px;overflow:auto;width:calc(100% - 48px);max-width:1592px;}.ge26ou0:first-of-type{margin-top:16px;}.ge26ou0:not(:last-of-type){margin-bottom:24px;}.ge26ou0 .pagination-wrapper{padding-top:12px;padding-bottom:0;}
|
|
@@ -40,7 +40,7 @@
|
|
|
40
40
|
.fykgn2i{background-color:#fff;height:100%;}
|
|
41
41
|
.fngr745{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;}
|
|
42
42
|
.t11wg61l{padding-bottom:16px;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;min-width:904px;}
|
|
43
|
-
.v1x3rivf{color:#
|
|
43
|
+
.v1x3rivf{color:#00122e;}
|
|
44
44
|
.tf5s6s.ant-tabs{-webkit-flex:1;-ms-flex:1;flex:1;min-height:0;}.tf5s6s.ant-tabs .ant-tabs-nav{margin-bottom:0;margin-right:24px;}.tf5s6s.ant-tabs .ant-tabs-nav-list{margin-left:24px;}.tf5s6s.ant-tabs .ant-tabs-content-holder{overflow:auto;}.tf5s6s.ant-tabs .ant-tabs-content-holder .ant-tabs-content,.tf5s6s.ant-tabs .ant-tabs-content-holder .ant-tabs-tabpane-active{height:100%;}
|
|
45
45
|
.b11tbgf7.ant-btn-quiet.ant-btn{color:rgba(44,56,82,0.75);}
|
|
46
46
|
.gtbyh5g{padding-bottom:12px;}
|
|
@@ -1508,235 +1508,6 @@
|
|
|
1508
1508
|
.e1cjl2b8{border-radius:8px;border:1px solid rgba(211,218,235,0.60);}.e1cjl2b8 .monaco-editor,.e1cjl2b8 .monaco-scrollable-element,.e1cjl2b8 .overflow-guard > .margin{border-radius:8px;}
|
|
1509
1509
|
.w1akirqw{height:100%;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}
|
|
1510
1510
|
.t30srnq{line-height:32px !important;}
|
|
1511
|
-
.c154n7ie{max-width:144px;}
|
|
1512
|
-
.c1c9j4da{width:100%;}
|
|
1513
|
-
.cjxv8cf{color:rgba(44,56,82,0.6);}
|
|
1514
|
-
.c1xsnuvk{-webkit-flex-basis:58%;-ms-flex-preferred-size:58%;flex-basis:58%;max-width:648px;width:100%;margin:0 auto;}
|
|
1515
|
-
.s1bsn3us{width:1px;height:16px;border-radius:1px;background:rgba(172,186,211,0.6);}
|
|
1516
|
-
|
|
1517
|
-
.e1guqlj2{-webkit-flex:1;-ms-flex:1;flex:1;height:100%;margin-bottom:16px;}
|
|
1518
|
-
.f1nltbcu{margin-bottom:16px;}
|
|
1519
|
-
.f1qgcca6.ant-modal.fullscreen .ant-modal-header{padding:60px 128px 32px 128px;}.f1qgcca6.ant-modal.fullscreen .ant-modal-body{padding:0 128px;}.f1qgcca6.ant-modal.fullscreen .ant-modal-footer .footer-content{margin:0 128px;}
|
|
1520
|
-
.m1tl3wq2 .ant-modal-header{max-width:648px;width:100%;padding:60px 0 32px 0 !important;margin:auto;}.m1tl3wq2 .ant-modal-body{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;width:100%;padding:0 4px !important;margin:auto;}.m1tl3wq2 .ant-modal-footer .footer-content{max-width:648px;width:100%;margin:auto !important;}.m1tl3wq2 .f1nltbcu{max-width:648px;width:100%;margin-left:auto;margin-right:auto;}
|
|
1521
|
-
.exjt4uc{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:4px;}
|
|
1522
|
-
/**
|
|
1523
|
-
* Copyright (c) 2014 The xterm.js authors. All rights reserved.
|
|
1524
|
-
* Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)
|
|
1525
|
-
* https://github.com/chjj/term.js
|
|
1526
|
-
* @license MIT
|
|
1527
|
-
*
|
|
1528
|
-
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
1529
|
-
* of this software and associated documentation files (the "Software"), to deal
|
|
1530
|
-
* in the Software without restriction, including without limitation the rights
|
|
1531
|
-
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
1532
|
-
* copies of the Software, and to permit persons to whom the Software is
|
|
1533
|
-
* furnished to do so, subject to the following conditions:
|
|
1534
|
-
*
|
|
1535
|
-
* The above copyright notice and this permission notice shall be included in
|
|
1536
|
-
* all copies or substantial portions of the Software.
|
|
1537
|
-
*
|
|
1538
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
1539
|
-
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
1540
|
-
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
1541
|
-
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
1542
|
-
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
1543
|
-
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
1544
|
-
* THE SOFTWARE.
|
|
1545
|
-
*
|
|
1546
|
-
* Originally forked from (with the author's permission):
|
|
1547
|
-
* Fabrice Bellard's javascript vt100 for jslinux:
|
|
1548
|
-
* http://bellard.org/jslinux/
|
|
1549
|
-
* Copyright (c) 2011 Fabrice Bellard
|
|
1550
|
-
* The original design remains. The terminal itself
|
|
1551
|
-
* has been extended to include xterm CSI codes, among
|
|
1552
|
-
* other features.
|
|
1553
|
-
*/
|
|
1554
|
-
|
|
1555
|
-
/**
|
|
1556
|
-
* Default styles for xterm.js
|
|
1557
|
-
*/
|
|
1558
|
-
|
|
1559
|
-
.xterm {
|
|
1560
|
-
cursor: text;
|
|
1561
|
-
position: relative;
|
|
1562
|
-
user-select: none;
|
|
1563
|
-
-ms-user-select: none;
|
|
1564
|
-
-webkit-user-select: none;
|
|
1565
|
-
}
|
|
1566
|
-
|
|
1567
|
-
.xterm.focus,
|
|
1568
|
-
.xterm:focus {
|
|
1569
|
-
outline: none;
|
|
1570
|
-
}
|
|
1571
|
-
|
|
1572
|
-
.xterm .xterm-helpers {
|
|
1573
|
-
position: absolute;
|
|
1574
|
-
top: 0;
|
|
1575
|
-
/**
|
|
1576
|
-
* The z-index of the helpers must be higher than the canvases in order for
|
|
1577
|
-
* IMEs to appear on top.
|
|
1578
|
-
*/
|
|
1579
|
-
z-index: 5;
|
|
1580
|
-
}
|
|
1581
|
-
|
|
1582
|
-
.xterm .xterm-helper-textarea {
|
|
1583
|
-
padding: 0;
|
|
1584
|
-
border: 0;
|
|
1585
|
-
margin: 0;
|
|
1586
|
-
/* Move textarea out of the screen to the far left, so that the cursor is not visible */
|
|
1587
|
-
position: absolute;
|
|
1588
|
-
opacity: 0;
|
|
1589
|
-
left: -9999em;
|
|
1590
|
-
top: 0;
|
|
1591
|
-
width: 0;
|
|
1592
|
-
height: 0;
|
|
1593
|
-
z-index: -5;
|
|
1594
|
-
/** Prevent wrapping so the IME appears against the textarea at the correct position */
|
|
1595
|
-
white-space: nowrap;
|
|
1596
|
-
overflow: hidden;
|
|
1597
|
-
resize: none;
|
|
1598
|
-
}
|
|
1599
|
-
|
|
1600
|
-
.xterm .composition-view {
|
|
1601
|
-
/* TODO: Composition position got messed up somewhere */
|
|
1602
|
-
background: #000;
|
|
1603
|
-
color: #FFF;
|
|
1604
|
-
display: none;
|
|
1605
|
-
position: absolute;
|
|
1606
|
-
white-space: nowrap;
|
|
1607
|
-
z-index: 1;
|
|
1608
|
-
}
|
|
1609
|
-
|
|
1610
|
-
.xterm .composition-view.active {
|
|
1611
|
-
display: block;
|
|
1612
|
-
}
|
|
1613
|
-
|
|
1614
|
-
.xterm .xterm-viewport {
|
|
1615
|
-
/* On OS X this is required in order for the scroll bar to appear fully opaque */
|
|
1616
|
-
background-color: #000;
|
|
1617
|
-
overflow-y: scroll;
|
|
1618
|
-
cursor: default;
|
|
1619
|
-
position: absolute;
|
|
1620
|
-
right: 0;
|
|
1621
|
-
left: 0;
|
|
1622
|
-
top: 0;
|
|
1623
|
-
bottom: 0;
|
|
1624
|
-
}
|
|
1625
|
-
|
|
1626
|
-
.xterm .xterm-screen {
|
|
1627
|
-
position: relative;
|
|
1628
|
-
}
|
|
1629
|
-
|
|
1630
|
-
.xterm .xterm-screen canvas {
|
|
1631
|
-
position: absolute;
|
|
1632
|
-
left: 0;
|
|
1633
|
-
top: 0;
|
|
1634
|
-
}
|
|
1635
|
-
|
|
1636
|
-
.xterm .xterm-scroll-area {
|
|
1637
|
-
visibility: hidden;
|
|
1638
|
-
}
|
|
1639
|
-
|
|
1640
|
-
.xterm-char-measure-element {
|
|
1641
|
-
display: inline-block;
|
|
1642
|
-
visibility: hidden;
|
|
1643
|
-
position: absolute;
|
|
1644
|
-
top: 0;
|
|
1645
|
-
left: -9999em;
|
|
1646
|
-
line-height: normal;
|
|
1647
|
-
}
|
|
1648
|
-
|
|
1649
|
-
.xterm.enable-mouse-events {
|
|
1650
|
-
/* When mouse events are enabled (eg. tmux), revert to the standard pointer cursor */
|
|
1651
|
-
cursor: default;
|
|
1652
|
-
}
|
|
1653
|
-
|
|
1654
|
-
.xterm.xterm-cursor-pointer,
|
|
1655
|
-
.xterm .xterm-cursor-pointer {
|
|
1656
|
-
cursor: pointer;
|
|
1657
|
-
}
|
|
1658
|
-
|
|
1659
|
-
.xterm.column-select.focus {
|
|
1660
|
-
/* Column selection mode */
|
|
1661
|
-
cursor: crosshair;
|
|
1662
|
-
}
|
|
1663
|
-
|
|
1664
|
-
.xterm .xterm-accessibility:not(.debug),
|
|
1665
|
-
.xterm .xterm-message {
|
|
1666
|
-
position: absolute;
|
|
1667
|
-
left: 0;
|
|
1668
|
-
top: 0;
|
|
1669
|
-
bottom: 0;
|
|
1670
|
-
right: 0;
|
|
1671
|
-
z-index: 10;
|
|
1672
|
-
color: transparent;
|
|
1673
|
-
pointer-events: none;
|
|
1674
|
-
}
|
|
1675
|
-
|
|
1676
|
-
.xterm .xterm-accessibility-tree:not(.debug) *::selection {
|
|
1677
|
-
color: transparent;
|
|
1678
|
-
}
|
|
1679
|
-
|
|
1680
|
-
.xterm .xterm-accessibility-tree {
|
|
1681
|
-
user-select: text;
|
|
1682
|
-
white-space: pre;
|
|
1683
|
-
}
|
|
1684
|
-
|
|
1685
|
-
.xterm .live-region {
|
|
1686
|
-
position: absolute;
|
|
1687
|
-
left: -9999px;
|
|
1688
|
-
width: 1px;
|
|
1689
|
-
height: 1px;
|
|
1690
|
-
overflow: hidden;
|
|
1691
|
-
}
|
|
1692
|
-
|
|
1693
|
-
.xterm-dim {
|
|
1694
|
-
/* Dim should not apply to background, so the opacity of the foreground color is applied
|
|
1695
|
-
* explicitly in the generated class and reset to 1 here */
|
|
1696
|
-
opacity: 1 !important;
|
|
1697
|
-
}
|
|
1698
|
-
|
|
1699
|
-
.xterm-underline-1 { text-decoration: underline; }
|
|
1700
|
-
.xterm-underline-2 { text-decoration: double underline; }
|
|
1701
|
-
.xterm-underline-3 { text-decoration: wavy underline; }
|
|
1702
|
-
.xterm-underline-4 { text-decoration: dotted underline; }
|
|
1703
|
-
.xterm-underline-5 { text-decoration: dashed underline; }
|
|
1704
|
-
|
|
1705
|
-
.xterm-overline {
|
|
1706
|
-
text-decoration: overline;
|
|
1707
|
-
}
|
|
1708
|
-
|
|
1709
|
-
.xterm-overline.xterm-underline-1 { text-decoration: overline underline; }
|
|
1710
|
-
.xterm-overline.xterm-underline-2 { text-decoration: overline double underline; }
|
|
1711
|
-
.xterm-overline.xterm-underline-3 { text-decoration: overline wavy underline; }
|
|
1712
|
-
.xterm-overline.xterm-underline-4 { text-decoration: overline dotted underline; }
|
|
1713
|
-
.xterm-overline.xterm-underline-5 { text-decoration: overline dashed underline; }
|
|
1714
|
-
|
|
1715
|
-
.xterm-strikethrough {
|
|
1716
|
-
text-decoration: line-through;
|
|
1717
|
-
}
|
|
1718
|
-
|
|
1719
|
-
.xterm-screen .xterm-decoration-container .xterm-decoration {
|
|
1720
|
-
z-index: 6;
|
|
1721
|
-
position: absolute;
|
|
1722
|
-
}
|
|
1723
|
-
|
|
1724
|
-
.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer {
|
|
1725
|
-
z-index: 7;
|
|
1726
|
-
}
|
|
1727
|
-
|
|
1728
|
-
.xterm-decoration-overview-ruler {
|
|
1729
|
-
z-index: 8;
|
|
1730
|
-
position: absolute;
|
|
1731
|
-
top: 0;
|
|
1732
|
-
right: 0;
|
|
1733
|
-
pointer-events: none;
|
|
1734
|
-
}
|
|
1735
|
-
|
|
1736
|
-
.xterm-decoration-top {
|
|
1737
|
-
z-index: 2;
|
|
1738
|
-
position: relative;
|
|
1739
|
-
}
|
|
1740
1511
|
.sj0ggy.ant-select{-webkit-align-self:flex-start;-ms-flex-item-align:start;align-self:flex-start;min-width:276px;max-width:100%;}.sj0ggy.ant-select .ant-select-selector{display:block;overflow:hidden;padding-right:32px;white-space:nowrap;}.sj0ggy.ant-select .ant-select-selector > span:nth-child(-n + 8):not(.ant-select-selection-search){display:inline-block;max-width:var(--tag-max-width);margin-right:4px;}.sj0ggy.ant-select .ant-select-selection-search{display:none;}.sj0ggy.ant-select .zoom-leave{opacity:0;position:absolute;}
|
|
1741
1512
|
.d1eo8uqs{border-radius:6px;}
|
|
1742
1513
|
.s64gojc.s64gojc.ant-input-affix-wrapper{border:unset;border-bottom:1px solid rgba(211,218,235,.6);border-radius:unset;box-shadow:unset;outline:unset;padding:5px 18px;}.s64gojc.s64gojc.ant-input-affix-wrapper:hover,.s64gojc.s64gojc.ant-input-affix-wrapper:focus{box-shadow:unset;outline:unset;}
|
|
@@ -1751,6 +1522,17 @@
|
|
|
1751
1522
|
.l1ng0psc{padding:12px 24px;-webkit-flex:1;-ms-flex:1;flex:1;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;min-height:0;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}
|
|
1752
1523
|
.tj6zpn4{-webkit-flex:1;-ms-flex:1;flex:1;min-height:0;}.tj6zpn4.table-wrapper{height:auto;-webkit-flex-shrink:1;-ms-flex-negative:1;flex-shrink:1;min-height:0;}
|
|
1753
1524
|
.n1rqcyjn.ant-select{margin-bottom:12px;}
|
|
1525
|
+
.c154n7ie{max-width:144px;}
|
|
1526
|
+
.c1c9j4da{width:100%;}
|
|
1527
|
+
.cjxv8cf{color:rgba(44,56,82,0.6);}
|
|
1528
|
+
.c1xsnuvk{-webkit-flex-basis:58%;-ms-flex-preferred-size:58%;flex-basis:58%;max-width:648px;width:100%;margin:0 auto;}
|
|
1529
|
+
.s1bsn3us{width:1px;height:16px;border-radius:1px;background:rgba(172,186,211,0.6);}
|
|
1530
|
+
|
|
1531
|
+
.e1guqlj2{-webkit-flex:1;-ms-flex:1;flex:1;height:100%;margin-bottom:16px;}
|
|
1532
|
+
.f1nltbcu{margin-bottom:16px;}
|
|
1533
|
+
.f1qgcca6.ant-modal.fullscreen .ant-modal-header{padding:60px 128px 32px 128px;}.f1qgcca6.ant-modal.fullscreen .ant-modal-body{padding:0 128px;}.f1qgcca6.ant-modal.fullscreen .ant-modal-footer .footer-content{margin:0 128px;}
|
|
1534
|
+
.m1tl3wq2 .ant-modal-header{max-width:648px;width:100%;padding:60px 0 32px 0 !important;margin:auto;}.m1tl3wq2 .ant-modal-body{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;width:100%;padding:0 4px !important;margin:auto;}.m1tl3wq2 .ant-modal-footer .footer-content{max-width:648px;width:100%;margin:auto !important;}.m1tl3wq2 .f1nltbcu{max-width:648px;width:100%;margin-left:auto;margin-right:auto;}
|
|
1535
|
+
.exjt4uc{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:4px;}
|
|
1754
1536
|
.c1pvtlkp{width:100%;}
|
|
1755
1537
|
.wfg6u6g{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;}.wfg6u6g .usage-text{width:50px;text-align:right;}.wfg6u6g .usage-bar{height:12px;width:100px;position:relative;border-radius:2px;}.wfg6u6g .request-anchor{position:absolute;left:10%;top:-3px;height:18px;width:2px;background:#777;z-index:9;}.wfg6u6g .usage-fill-bar{position:absolute;left:0;top:0;height:100%;background:rgba(0,128,255,0.6);z-index:7;}.wfg6u6g .request-bar{position:absolute;left:0;top:0;height:100%;background:#d8deeb;z-index:5;}.wfg6u6g .request-to-limit-bar{position:absolute;right:0;top:0;height:100%;background:#d8deeb;z-index:5;}.wfg6u6g .request-to-limit-bar.no-limit{background:linear-gradient(to right,#d8deeb 50%,#d8deeb 50%);background-size:4px 100%;}.wfg6u6g .request-to-limit-bar.no-limit.exceed-request{background:linear-gradient(to right,#d8deeb 50%,rgba(0,128,255,0.6) 50%);background-size:4px 100%;}
|
|
1756
1538
|
.mdppgn0.ant-menu{background:#edf0f7;padding:8px;}.mdppgn0.ant-menu .ant-menu-item-selected{background:linear-gradient(90deg,#0080ff,#005ed1);border-radius:6px;box-shadow:0 1px 2px rgba(184,192,204,0.6);color:#fff;}.mdppgn0.ant-menu .ant-menu-item-selected a:hover{color:#fff;}.mdppgn0.ant-menu .ant-menu-item:not(.ant-menu-item-selected):hover{background:linear-gradient(90deg,#fff,hsla(0,0%,100%,0.6));border-radius:6px;box-shadow:0 0 4px rgba(235,239,245,0.6),0 8px 16px rgba(129,138,153,0.18);}
|
package/lib/src/App.js
ADDED
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { createBrowserHistory } from 'history';
|
|
3
|
+
import { GlobalStore } from 'k8s-api-provider';
|
|
4
|
+
import { useMemo } from 'react';
|
|
5
|
+
import { I18nextProvider } from 'react-i18next';
|
|
6
|
+
import { Route, Router } from 'react-router-dom';
|
|
7
|
+
import { Layout } from './components';
|
|
8
|
+
import { CRONJOB_INIT_VALUE, DAEMONSET_INIT_VALUE, STATEFULSET_INIT_VALUE, POD_INIT_VALUE, } from './constants/k8s';
|
|
9
|
+
import { Dovetail } from './Dovetail';
|
|
10
|
+
import i18n from './i18n';
|
|
11
|
+
import { ConfigMapConfig } from './pages/configmaps';
|
|
12
|
+
import { CronJobForm, CronJobList, CronJobShow } from './pages/cronjobs';
|
|
13
|
+
import { DaemonSetForm, DaemonSetList, DaemonSetShow } from './pages/daemonsets';
|
|
14
|
+
import { DeploymentForm, DeploymentList, DeploymentShow } from './pages/deployments';
|
|
15
|
+
import { IngressConfig } from './pages/ingresses';
|
|
16
|
+
import { JobConfig } from './pages/jobs';
|
|
17
|
+
import { NetworkPolicyConfig } from './pages/networkPolicies';
|
|
18
|
+
import { PodShow, PodList, PodForm } from './pages/pods';
|
|
19
|
+
import { SecretsConfig } from './pages/secrets';
|
|
20
|
+
import { ServicesConfig } from './pages/services';
|
|
21
|
+
import { StatefulSetShow, StatefulSetList, StatefulSetForm } from './pages/statefulsets';
|
|
22
|
+
import { ProviderPlugins } from './plugins';
|
|
23
|
+
import { RESOURCE_GROUP, FormType } from './types';
|
|
24
|
+
function App() {
|
|
25
|
+
const histroy = createBrowserHistory();
|
|
26
|
+
const resourcesConfig = useMemo(() => {
|
|
27
|
+
return [
|
|
28
|
+
{
|
|
29
|
+
name: 'cronjobs',
|
|
30
|
+
basePath: '/apis/batch/v1beta1',
|
|
31
|
+
kind: 'CronJob',
|
|
32
|
+
parent: RESOURCE_GROUP.WORKLOAD,
|
|
33
|
+
label: 'CronJobs',
|
|
34
|
+
initValue: CRONJOB_INIT_VALUE,
|
|
35
|
+
isCustom: true,
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
name: 'daemonsets',
|
|
39
|
+
basePath: '/apis/apps/v1',
|
|
40
|
+
kind: 'DaemonSet',
|
|
41
|
+
parent: RESOURCE_GROUP.WORKLOAD,
|
|
42
|
+
label: 'DaemonSets',
|
|
43
|
+
initValue: DAEMONSET_INIT_VALUE,
|
|
44
|
+
isCustom: true,
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
name: 'deployments',
|
|
48
|
+
basePath: '/apis/apps/v1',
|
|
49
|
+
kind: 'Deployment',
|
|
50
|
+
parent: RESOURCE_GROUP.WORKLOAD,
|
|
51
|
+
label: 'Deployments',
|
|
52
|
+
formType: FormType.MODAL,
|
|
53
|
+
FormModal: DeploymentForm,
|
|
54
|
+
isCustom: true,
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
name: 'statefulsets',
|
|
58
|
+
basePath: '/apis/apps/v1',
|
|
59
|
+
kind: 'StatefulSet',
|
|
60
|
+
parent: RESOURCE_GROUP.WORKLOAD,
|
|
61
|
+
label: 'StatefulSets',
|
|
62
|
+
initValue: STATEFULSET_INIT_VALUE,
|
|
63
|
+
isCustom: true,
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
name: 'pods',
|
|
67
|
+
basePath: '/api/v1',
|
|
68
|
+
kind: 'Pod',
|
|
69
|
+
parent: RESOURCE_GROUP.WORKLOAD,
|
|
70
|
+
label: 'Pods',
|
|
71
|
+
initValue: POD_INIT_VALUE,
|
|
72
|
+
isCustom: true,
|
|
73
|
+
},
|
|
74
|
+
JobConfig,
|
|
75
|
+
IngressConfig,
|
|
76
|
+
NetworkPolicyConfig,
|
|
77
|
+
ConfigMapConfig,
|
|
78
|
+
SecretsConfig,
|
|
79
|
+
ServicesConfig,
|
|
80
|
+
];
|
|
81
|
+
}, []);
|
|
82
|
+
const globalStore = useMemo(() => {
|
|
83
|
+
return new GlobalStore({
|
|
84
|
+
apiUrl: '/api/k8s',
|
|
85
|
+
watchWsApiUrl: 'api/sks-ws/k8s',
|
|
86
|
+
prefix: 'default',
|
|
87
|
+
}, ProviderPlugins);
|
|
88
|
+
}, []);
|
|
89
|
+
return (_jsx(I18nextProvider, { i18n: i18n, children: _jsx(Dovetail, { resourcesConfig: resourcesConfig, Layout: Layout, history: histroy, globalStore: globalStore, children: _jsxs(Router, { history: histroy, children: [_jsx(Route, { path: "/cronjobs", exact: true, children: _jsx(CronJobList, {}) }), _jsx(Route, { path: "/cronjobs/show", children: _jsx(CronJobShow, {}) }), _jsx(Route, { path: "/cronjobs/create", children: _jsx(CronJobForm, {}) }), _jsx(Route, { path: "/cronjobs/edit", children: _jsx(CronJobForm, {}) }), _jsx(Route, { path: "/daemonsets", exact: true, children: _jsx(DaemonSetList, {}) }), _jsx(Route, { path: "/daemonsets/show", children: _jsx(DaemonSetShow, {}) }), _jsx(Route, { path: "/daemonsets/create", children: _jsx(DaemonSetForm, {}) }), _jsx(Route, { path: "/daemonsets/edit", children: _jsx(DaemonSetForm, {}) }), _jsx(Route, { path: "/deployments", exact: true, children: _jsx(DeploymentList, {}) }), _jsx(Route, { path: "/deployments/show", children: _jsx(DeploymentShow, {}) }), _jsx(Route, { path: "/statefulsets", exact: true, children: _jsx(StatefulSetList, {}) }), _jsx(Route, { path: "/statefulsets/show", children: _jsx(StatefulSetShow, {}) }), _jsx(Route, { path: "/statefulsets/create", children: _jsx(StatefulSetForm, {}) }), _jsx(Route, { path: "/statefulsets/edit", children: _jsx(StatefulSetForm, {}) }), _jsx(Route, { path: "/pods", exact: true, children: _jsx(PodList, {}) }), _jsx(Route, { path: "/pods/show", children: _jsx(PodShow, {}) }), _jsx(Route, { path: "/pods/create", children: _jsx(PodForm, {}) }), _jsx(Route, { path: "/pods/edit", children: _jsx(PodForm, {}) })] }) }) }));
|
|
90
|
+
}
|
|
91
|
+
export default App;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { KitStoreProvider, ModalStack } from '@cloudtower/eagle';
|
|
3
|
+
import { Refine } from '@refinedev/core';
|
|
4
|
+
import { dataProvider, liveProvider } from 'k8s-api-provider';
|
|
5
|
+
import { keyBy } from 'lodash-es';
|
|
6
|
+
import { useMemo } from 'react';
|
|
7
|
+
import { Router } from 'react-router-dom';
|
|
8
|
+
import ConfigsContext from 'src/contexts/configs';
|
|
9
|
+
import { ResourceCRUD } from './components/ResourceCRUD';
|
|
10
|
+
import GlobalStoreContext from './contexts/global-store';
|
|
11
|
+
import { routerProvider } from './providers/router-provider';
|
|
12
|
+
import './styles.css';
|
|
13
|
+
export const Dovetail = props => {
|
|
14
|
+
const { resourcesConfig, urlPrefix = '', Layout, history, globalStore } = props;
|
|
15
|
+
const notCustomResources = useMemo(() => {
|
|
16
|
+
return resourcesConfig.filter(c => !c.isCustom);
|
|
17
|
+
}, [resourcesConfig]);
|
|
18
|
+
const content = useMemo(() => {
|
|
19
|
+
const _content = (_jsxs(_Fragment, { children: [_jsx(ModalStack, {}), _jsx(ResourceCRUD, { configs: notCustomResources, urlPrefix: urlPrefix }), props.children] }));
|
|
20
|
+
if (Layout) {
|
|
21
|
+
return _jsx(Layout, { children: _content });
|
|
22
|
+
}
|
|
23
|
+
return _content;
|
|
24
|
+
}, [Layout, notCustomResources, props.children, urlPrefix]);
|
|
25
|
+
return (_jsx(Router, { history: history, children: _jsx(KitStoreProvider, { children: _jsx(GlobalStoreContext.Provider, { value: { globalStore }, children: _jsx(ConfigsContext.Provider, { value: keyBy(resourcesConfig, 'name'), children: _jsx(Refine, { dataProvider: {
|
|
26
|
+
default: dataProvider(globalStore),
|
|
27
|
+
}, routerProvider: routerProvider, liveProvider: liveProvider(globalStore), options: {
|
|
28
|
+
warnWhenUnsavedChanges: true,
|
|
29
|
+
liveMode: 'auto',
|
|
30
|
+
}, resources: resourcesConfig.map(c => {
|
|
31
|
+
return {
|
|
32
|
+
name: c.name,
|
|
33
|
+
meta: {
|
|
34
|
+
resourceBasePath: c.basePath,
|
|
35
|
+
kind: c.kind,
|
|
36
|
+
parent: c.parent,
|
|
37
|
+
label: `${c.kind}s`,
|
|
38
|
+
},
|
|
39
|
+
list: `${urlPrefix}/${c.name}`,
|
|
40
|
+
show: `${urlPrefix}/${c.name}/show`,
|
|
41
|
+
create: `${urlPrefix}/${c.name}/create`,
|
|
42
|
+
edit: `${urlPrefix}/${c.name}/edit`,
|
|
43
|
+
};
|
|
44
|
+
}), children: content }) }) }) }) }));
|
|
45
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { css, cx } from '@linaria/core';
|
|
3
|
+
import { useBreadcrumb } from '@refinedev/core';
|
|
4
|
+
import { Link } from 'react-router-dom';
|
|
5
|
+
const BreadcrumbStyle = css `
|
|
6
|
+
display: flex;
|
|
7
|
+
|
|
8
|
+
.breadcrumb-item {
|
|
9
|
+
&:not(:last-of-type):after {
|
|
10
|
+
content: '>';
|
|
11
|
+
margin: 0 8px;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
`;
|
|
15
|
+
export function Breadcrumb(props) {
|
|
16
|
+
const { breadcrumbs } = useBreadcrumb();
|
|
17
|
+
return (_jsx("ul", { className: cx(BreadcrumbStyle, props.className), children: breadcrumbs.map(breadcrumb => {
|
|
18
|
+
return (_jsx("li", { className: "breadcrumb-item", children: breadcrumb.href ? (_jsx(Link, { to: breadcrumb.href, children: breadcrumb.label })) : (_jsx("span", { children: breadcrumb.label })) }, `breadcrumb-${breadcrumb.label}`));
|
|
19
|
+
}) }));
|
|
20
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useUIKit } from '@cloudtower/eagle';
|
|
3
|
+
import { useD2Translation } from '../../i18n';
|
|
4
|
+
import { addId } from '../../utils/addId';
|
|
5
|
+
import ErrorContent from '../Table/ErrorContent';
|
|
6
|
+
import Time from '../Time';
|
|
7
|
+
export const ConditionsTable = ({ conditions = [] }) => {
|
|
8
|
+
const kit = useUIKit();
|
|
9
|
+
const { t } = useD2Translation();
|
|
10
|
+
const conditionsWithId = addId(conditions, 'type');
|
|
11
|
+
const columns = [
|
|
12
|
+
{
|
|
13
|
+
key: 'type',
|
|
14
|
+
display: true,
|
|
15
|
+
dataIndex: 'type',
|
|
16
|
+
title: t('dovetail.condition'),
|
|
17
|
+
sortable: true,
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
key: 'status',
|
|
21
|
+
display: true,
|
|
22
|
+
dataIndex: 'status',
|
|
23
|
+
title: t('dovetail.status'),
|
|
24
|
+
sortable: true,
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
key: 'reason',
|
|
28
|
+
display: true,
|
|
29
|
+
dataIndex: 'reason',
|
|
30
|
+
title: t('dovetail.reason'),
|
|
31
|
+
sortable: true,
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
key: 'lastUpdateTime',
|
|
35
|
+
display: true,
|
|
36
|
+
dataIndex: 'lastUpdateTime',
|
|
37
|
+
title: t('dovetail.updated_time'),
|
|
38
|
+
sortable: true,
|
|
39
|
+
render: (value, record) => {
|
|
40
|
+
const time = value || record.lastTransitionTime;
|
|
41
|
+
return _jsx(Time, { date: new Date(time) });
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
key: 'message',
|
|
46
|
+
display: true,
|
|
47
|
+
dataIndex: 'message',
|
|
48
|
+
title: t('dovetail.message'),
|
|
49
|
+
sortable: true,
|
|
50
|
+
},
|
|
51
|
+
];
|
|
52
|
+
if (conditionsWithId.length === 0) {
|
|
53
|
+
return _jsx(ErrorContent, { errorText: t('dovetail.empty'), style: { padding: '15px 0' } });
|
|
54
|
+
}
|
|
55
|
+
return (_jsx(kit.table, { loading: false, dataSource: conditionsWithId, columns: columns, rowKey: "type", empty: t('dovetail.empty') }));
|
|
56
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './ConditionsTable';
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useUIKit } from '@cloudtower/eagle';
|
|
3
|
+
import { useOpenForm } from 'src/hooks/useOpenForm';
|
|
4
|
+
import { useD2Translation } from '../../i18n';
|
|
5
|
+
export function CreateButton() {
|
|
6
|
+
const kit = useUIKit();
|
|
7
|
+
const { t } = useD2Translation();
|
|
8
|
+
const openForm = useOpenForm();
|
|
9
|
+
return (_jsx(kit.button, { type: "primary", onClick: openForm, children: t('dovetail.create') }));
|
|
10
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Icon, useUIKit } from '@cloudtower/eagle';
|
|
3
|
+
import { SuspendedPause16GradientGrayIcon, VmResume16Icon, } from '@cloudtower/icons-react';
|
|
4
|
+
import { useResource, useUpdate } from '@refinedev/core';
|
|
5
|
+
import { useD2Translation } from '../../i18n';
|
|
6
|
+
import { pruneBeforeEdit } from '../../utils/k8s';
|
|
7
|
+
import K8sDropdown from '../K8sDropdown';
|
|
8
|
+
export function CronJobDropdown(props) {
|
|
9
|
+
const { record } = props;
|
|
10
|
+
const { spec } = record;
|
|
11
|
+
const kit = useUIKit();
|
|
12
|
+
const { resource } = useResource();
|
|
13
|
+
const { mutate } = useUpdate();
|
|
14
|
+
const { t } = useD2Translation();
|
|
15
|
+
const suspended = Boolean(spec?.suspend);
|
|
16
|
+
return (_jsx(K8sDropdown, { record: record, children: _jsx(kit.menu.Item, { onClick: () => {
|
|
17
|
+
const v = suspended ? record.resume() : record.suspend();
|
|
18
|
+
const id = record.id;
|
|
19
|
+
pruneBeforeEdit(v);
|
|
20
|
+
mutate({
|
|
21
|
+
id,
|
|
22
|
+
resource: resource?.name || '',
|
|
23
|
+
values: v,
|
|
24
|
+
});
|
|
25
|
+
}, children: _jsx(Icon, { src: suspended ? VmResume16Icon : SuspendedPause16GradientGrayIcon, children: t(suspended ? 'dovetail.resume' : 'dovetail.suspend') }) }) }));
|
|
26
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useUIKit } from '@cloudtower/eagle';
|
|
3
|
+
import { css } from '@linaria/core';
|
|
4
|
+
import { useList } from '@refinedev/core';
|
|
5
|
+
import { useMemo, useState } from 'react';
|
|
6
|
+
import { AgeColumnRenderer, CompletionsCountColumnRenderer, DurationColumnRenderer, NameColumnRenderer, NameSpaceColumnRenderer, StateDisplayColumnRenderer, WorkloadImageColumnRenderer, } from '../../hooks/useEagleTable/columns';
|
|
7
|
+
import { useD2Translation } from '../../i18n';
|
|
8
|
+
import Table from '../Table';
|
|
9
|
+
import { TableToolBar } from '../Table/TableToolBar';
|
|
10
|
+
function matchOwner(job, owner) {
|
|
11
|
+
let match = false;
|
|
12
|
+
// TODO: use relations
|
|
13
|
+
for (const o of job.metadata?.ownerReferences || []) {
|
|
14
|
+
if (o.apiVersion === owner.apiVersion &&
|
|
15
|
+
o.kind === owner.kind &&
|
|
16
|
+
o.name === owner.name &&
|
|
17
|
+
job.namespace === owner.namespace) {
|
|
18
|
+
match = true;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return match;
|
|
22
|
+
}
|
|
23
|
+
export const CronjobJobsTable = ({ owner }) => {
|
|
24
|
+
const { i18n } = useD2Translation();
|
|
25
|
+
const kit = useUIKit();
|
|
26
|
+
const [selectedKeys, setSelectedKeys] = useState([]);
|
|
27
|
+
const [currentPage, setCurrentPage] = useState(1);
|
|
28
|
+
const { data } = useList({
|
|
29
|
+
resource: 'jobs',
|
|
30
|
+
meta: { resourceBasePath: '/apis/batch/v1', kind: 'Job' },
|
|
31
|
+
});
|
|
32
|
+
const dataSource = useMemo(() => {
|
|
33
|
+
return data?.data.filter(p => {
|
|
34
|
+
return owner ? matchOwner(p, owner) : true;
|
|
35
|
+
});
|
|
36
|
+
}, [data?.data, owner]);
|
|
37
|
+
const columns = [
|
|
38
|
+
NameColumnRenderer(i18n, 'jobs'),
|
|
39
|
+
StateDisplayColumnRenderer(i18n),
|
|
40
|
+
NameSpaceColumnRenderer(i18n),
|
|
41
|
+
WorkloadImageColumnRenderer(i18n),
|
|
42
|
+
CompletionsCountColumnRenderer(i18n),
|
|
43
|
+
DurationColumnRenderer(i18n),
|
|
44
|
+
AgeColumnRenderer(i18n),
|
|
45
|
+
];
|
|
46
|
+
return (_jsxs(kit.space, { direction: "vertical", className: css `
|
|
47
|
+
width: 100%;
|
|
48
|
+
`, children: [_jsx(TableToolBar, { title: "Jobs", selectedKeys: selectedKeys, hideCreate: true }), _jsx(Table, { tableKey: "cronjobs", loading: !dataSource, data: dataSource || [], columns: columns, onSelect: keys => setSelectedKeys(keys), rowKey: "id", error: false, currentPage: currentPage, onPageChange: p => setCurrentPage(p), currentSize: 10, refetch: () => null })] }));
|
|
49
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useUIKit } from '@cloudtower/eagle';
|
|
3
|
+
import { useResource, useParsed } from '@refinedev/core';
|
|
4
|
+
import { useDeleteModal } from '../../hooks/useDeleteModal';
|
|
5
|
+
import { useD2Translation } from '../../i18n';
|
|
6
|
+
export const DeleteButton = () => {
|
|
7
|
+
const { resource } = useResource();
|
|
8
|
+
const { id } = useParsed();
|
|
9
|
+
const kit = useUIKit();
|
|
10
|
+
const { t } = useD2Translation();
|
|
11
|
+
const { modalProps, visible, openDeleteConfirmModal } = useDeleteModal(resource?.name || '');
|
|
12
|
+
return (_jsxs(_Fragment, { children: [_jsx(kit.button, { type: "primary", danger: true, onClick: () => openDeleteConfirmModal(id || ''), children: t('dovetail.delete') }), visible ? _jsx(kit.modal, { ...modalProps }) : null] }));
|
|
13
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useUIKit } from '@cloudtower/eagle';
|
|
3
|
+
import { useResource } from '@refinedev/core';
|
|
4
|
+
import { useCallback } from 'react';
|
|
5
|
+
import { useDeleteManyModal } from '../../hooks/useDeleteModal/useDeleteManyModal';
|
|
6
|
+
import { useD2Translation } from '../../i18n';
|
|
7
|
+
export const DeleteManyButton = props => {
|
|
8
|
+
const { resource } = useResource();
|
|
9
|
+
const kit = useUIKit();
|
|
10
|
+
const { t } = useD2Translation();
|
|
11
|
+
const { modalProps, visible, setVisible } = useDeleteManyModal(resource?.name || '', props.ids);
|
|
12
|
+
const onClick = useCallback(() => {
|
|
13
|
+
setVisible(true);
|
|
14
|
+
}, [setVisible]);
|
|
15
|
+
return (_jsxs(_Fragment, { children: [_jsx(kit.button, { type: "primary", danger: true, onClick: onClick, children: t('dovetail.delete') }), visible ? _jsx(kit.modal, { ...modalProps }) : null] }));
|
|
16
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useUIKit } from '@cloudtower/eagle';
|
|
3
|
+
import { useNavigation, useParsed, useShow } from '@refinedev/core';
|
|
4
|
+
import { Drawer } from 'antd';
|
|
5
|
+
import { ShowContent } from '../ShowContent';
|
|
6
|
+
export const DrawerShow = (props) => {
|
|
7
|
+
const kit = useUIKit();
|
|
8
|
+
const parsed = useParsed();
|
|
9
|
+
const nav = useNavigation();
|
|
10
|
+
const { queryResult } = useShow({ id: parsed?.params?.id });
|
|
11
|
+
const { isLoading } = queryResult;
|
|
12
|
+
return (_jsx(Drawer, { title: "Show Drawer", placement: "right", onClose: () => nav.goBack(), width: "50%", visible: !!parsed?.params?.id, children: isLoading ? _jsx(kit.loading, {}) : _jsx(ShowContent, { ...props }) }));
|
|
13
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './DrawerShow';
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useUIKit } from '@cloudtower/eagle';
|
|
3
|
+
import { useParsed } from '@refinedev/core';
|
|
4
|
+
import { useEdit } from '../../hooks/useEdit';
|
|
5
|
+
export const EditButton = () => {
|
|
6
|
+
const { id } = useParsed();
|
|
7
|
+
const kit = useUIKit();
|
|
8
|
+
const { edit } = useEdit();
|
|
9
|
+
return (_jsx(kit.button, { type: "primary", onClick: () => {
|
|
10
|
+
if (id)
|
|
11
|
+
edit(id);
|
|
12
|
+
}, children: "Edit" }));
|
|
13
|
+
};
|