@dovetail-v2/refine 0.0.37 → 0.0.39
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-1aeca078.js → MonacoYamlDiffEditor-a74de414.js} +1 -1
- package/dist/{index-1003469d.js → index-a278c0e3.js} +199 -113
- package/dist/refine.js +1 -1
- package/dist/refine.umd.cjs +196 -110
- package/dist/style.css +23 -21
- package/lib/src/App.js +91 -0
- package/lib/src/Dovetail.d.ts +1 -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.d.ts +6 -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/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/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.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.d.ts +1 -1
- 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.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.js +157 -0
- 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/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.js +38 -0
- package/lib/src/constants/index.js +2 -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.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.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.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.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.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/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/service-model.js +17 -0
- package/lib/src/models/statefulset-model.js +17 -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.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/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/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 +2 -0
- 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 +3 -3
- package/lib/src/components/ModalContextProvider/index.d.ts +0 -12
- package/lib/src/hooks/useModal.d.ts +0 -0
- 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/types/metric.d.ts +0 -25
package/dist/style.css
CHANGED
|
@@ -1,21 +1,20 @@
|
|
|
1
1
|
.t1vq0ett{margin-bottom:4px;}
|
|
2
2
|
.t139onst{color:rgba(44,56,82,0.60);}
|
|
3
|
-
.
|
|
3
|
+
.n18lzor8.ant-tag.ant-tag-gray{background-color:rgba(237,241,250,.6);border:1px solid rgba(211,218,235,.6);color:#00122e;}
|
|
4
|
+
.mvvgkkc.ant-modal .ant-modal-content{border-radius:16px;}.mvvgkkc.ant-modal .ant-modal-header{border-radius:16px 16px 0 0;}
|
|
4
5
|
.e5223w8.e5223w8{color:rgba(0,21,64,.3);}
|
|
5
6
|
.cdjsw14{width:100%;}.cdjsw14.overflow{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
|
|
6
7
|
.b142d7q8{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;}.b142d7q8 .breadcrumb-item:not(:last-of-type):after{content:'>';margin:0 8px;}
|
|
7
8
|
.egn3dbn{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;height:100%;}
|
|
8
|
-
.e136jgy8{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;}.e136jgy8 .title{margin-bottom:8px;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-image:linear-gradient(211.41deg,#929dad 0%,#d3dbe3 100%);}
|
|
9
|
-
.eckm4od{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;height:100%;}
|
|
10
|
-
.e1hl982n{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;}.e1hl982n .title{margin-bottom:8px;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-image:linear-gradient(211.41deg,#929dad 0%,#d3dbe3 100%);}
|
|
9
|
+
.e136jgy8{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;}.e136jgy8 .title{margin-bottom:8px;}.e136jgy8 .title.widget{background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-image:linear-gradient(211.41deg,#929dad 0%,#d3dbe3 100%);}.e136jgy8 .title.list{color:rgba(44,56,82,0.60);}.e136jgy8 .title.card{color:rgba(0,21,64,0.30);}
|
|
11
10
|
.ax1qopv{position:absolute;top:0;left:0;bottom:0;width:1px;background:$blue-60;-webkit-transform:translateX(-9999px);-ms-transform:translateX(-9999px);transform:translateX(-9999px);z-index:999;}.ax1qopv::before{content:'';position:absolute;height:34px;width:3px;top:0;left:-1px;background:$blue-60;}
|
|
12
11
|
.t1upn1sz{width:100%;border-top:1px solid rgba(211,218,235,0.6);display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}.t1upn1sz .ant-table-pagination{display:none;}.t1upn1sz .table-container{min-height:0;}
|
|
13
12
|
.b1vtjd4k.ant-btn.ant-btn-link{display:block;}
|
|
14
13
|
.luro4rx.ant-btn.ant-btn-link{line-height:18px;height:18px;}
|
|
15
14
|
.t13a6vox{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;max-width:100%;gap:8px 8px;}
|
|
16
|
-
.t12ikbmp{overflow:hidden;text-overflow:ellipsis;color:#1D326C;}.t12ikbmp
|
|
15
|
+
.t12ikbmp.ant-tag{overflow:hidden;text-overflow:ellipsis;color:#1D326C;}.t12ikbmp.ant-tag.outside-tag{background-color:rgba(211,218,235,0.60);}.t12ikbmp.ant-tag .inside-tag{background-color:rgba(192,203,224,0.60);}
|
|
17
16
|
.s8qkbck.ant-tag{padding:3px 16px;height:24px;}.s8qkbck.no-background{background-color:transparent !important;padding:0;}
|
|
18
|
-
.t19ustft{
|
|
17
|
+
.t19ustft{display:inline-block;line-height:18px;height:18px;border-bottom:1px dashed rgba(107,128,167,0.6);}
|
|
19
18
|
.t1v3ienx{padding:12px 24px;}
|
|
20
19
|
.tgejfwe{-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;width:100%;}
|
|
21
20
|
.tq6dc79{color:#00122E;}
|
|
@@ -23,7 +22,7 @@
|
|
|
23
22
|
.w16agr8o.ant-space{width:100%;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;}
|
|
24
23
|
.i1u1f5zp{white-space:pre-line;}
|
|
25
24
|
.c8jy7dc{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;padding:8px 10px;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row;-webkit-align-items:flex-start;-webkit-box-align:flex-start;-ms-flex-align:flex-start;align-items:flex-start;gap:8px;-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch;border-radius:4px;background:rgba(237,241,250,0.6);}.c8jy7dc:not(:last-of-type){margin-bottom:8px;}
|
|
26
|
-
.k2sddxl{color:rgba(44,56,82,0.6);width:calc(30% - 4px);margin-right:8px;}
|
|
25
|
+
.k2sddxl{color:rgba(44,56,82,0.6);width:calc(30% - 4px);margin-right:8px;word-break:break-all;}
|
|
27
26
|
.v16vicsr{word-break:break-all;width:calc(70% - 4px);}
|
|
28
27
|
.w14056kz{width:100%;}
|
|
29
28
|
.hisq2gt{width:100%;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;}.hisq2gt.expanded{margin-bottom:8px;}
|
|
@@ -31,17 +30,18 @@
|
|
|
31
30
|
.e1i58tpl.ant-btn.ant-btn-link{height:18px;line-height:18px;font-size:12px;}
|
|
32
31
|
.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
32
|
.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
|
-
.t1ohe42f{padding:16px 24px 8px 24px;background-color:#fff;}
|
|
33
|
+
.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
34
|
.nqm4qz0{color:#00122E;margin-right:8px;}
|
|
36
35
|
.ticl0qc{-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;width:100%;}
|
|
37
36
|
.so9uwk1{width:100%;}
|
|
38
|
-
.ge26ou0{padding:12px 16px;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;
|
|
39
|
-
.g17f8vl9{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;color:#1d326c;margin-bottom:12px;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;}
|
|
37
|
+
.ge26ou0{padding:12px 16px;padding-bottom:8px;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;}
|
|
38
|
+
.g17f8vl9{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;color:#1d326c;margin-bottom:12px;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;}
|
|
40
39
|
.fykgn2i{background-color:#fff;height:100%;}
|
|
41
40
|
.fngr745{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;}
|
|
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:
|
|
41
|
+
.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
42
|
.v1x3rivf{color:#00122E;}
|
|
44
|
-
.tf5s6s.ant-tabs{-webkit-flex:1;-ms-flex:1;flex:1;min-height:0;}.tf5s6s.ant-tabs .ant-tabs-nav{margin-bottom:0;}.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%;}
|
|
43
|
+
.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%;}
|
|
44
|
+
.b11tbgf7.ant-btn-quiet.ant-btn{color:rgba(44,56,82,0.75);}
|
|
45
45
|
.c1dicff8{width:100%;vertical-align:top;}
|
|
46
46
|
.esoz3jw .ant-modal-content{border-radius:16px;}.esoz3jw .ant-modal-header{border-radius:16px 16px 0 0;}
|
|
47
47
|
.e1m0bgls.ant-btn.ant-btn-link{height:22px;margin-left:8px;}
|
|
@@ -1508,14 +1508,15 @@
|
|
|
1508
1508
|
.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;}
|
|
1509
1509
|
.t30srnq{line-height:32px !important;}
|
|
1510
1510
|
.sj0ggy.ant-select .ant-select-selector{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;overflow:hidden;gap:4px;}.sj0ggy.ant-select .ant-select-selector > span{max-width:calc(100% - 76px);-webkit-flex-shrink:0;-ms-flex-negative:0;flex-shrink:0;}.sj0ggy.ant-select .ant-select-selection-search{display:none;}.sj0ggy.ant-select .zoom-leave{opacity:0;position:absolute;}
|
|
1511
|
-
.
|
|
1512
|
-
.s64gojc
|
|
1513
|
-
.
|
|
1514
|
-
.
|
|
1515
|
-
|
|
1516
|
-
|
|
1517
|
-
.
|
|
1518
|
-
.
|
|
1511
|
+
.d1eo8uqs{border-radius:6px;}
|
|
1512
|
+
.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;}
|
|
1513
|
+
.s16fqgtu .ant-select-item-group{border-bottom:1px solid rgba(211,218,235,0.6);min-height:0;padding:0;overflow:hidden;margin:6px 0;}
|
|
1514
|
+
.tgaujbg{max-width:100%;margin-right:0 !important;}
|
|
1515
|
+
.c1vbd54v{-webkit-flex-shrink:0;-ms-flex-negative:0;flex-shrink:0;margin-right:0;}
|
|
1516
|
+
|
|
1517
|
+
.lqrghwd{margin-right:8px;}
|
|
1518
|
+
.api7z1z{border-radius:4px;margin:6px;margin-bottom:0;padding:4px 8px 4px 12px;}
|
|
1519
|
+
.o38b23x.ant-select-item{margin:0 6px;border-radius:4px;padding:4px 8px 4px 12px;}.o38b23x.ant-select-item:not(:last-of-type){margin-bottom:3px;}.o38b23x.ant-select-item:last-of-type{margin-bottom:6px;}
|
|
1519
1520
|
.laykzsq{width:100%;height:100%;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}
|
|
1520
1521
|
.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;}
|
|
1521
1522
|
.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;}
|
|
@@ -1525,7 +1526,8 @@
|
|
|
1525
1526
|
|
|
1526
1527
|
.e1guqlj2{-webkit-flex:1;-ms-flex:1;flex:1;height:100%;margin-bottom:16px;}
|
|
1527
1528
|
.f1nltbcu.ant-modal.fullscreen .ant-modal-header{padding:60px 128px 32px 128px;}.f1nltbcu.ant-modal.fullscreen .ant-modal-body{padding:0 128px;}.f1nltbcu.ant-modal.fullscreen .ant-modal-footer{padding:15px 128px;}
|
|
1528
|
-
.
|
|
1529
|
+
.f1qgcca6{margin-bottom:16px;}
|
|
1530
|
+
.e1tl3wq2{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;}
|
|
1529
1531
|
.c1pvtlkp{width:100%;}
|
|
1530
1532
|
.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%;}
|
|
1531
1533
|
.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;
|
package/lib/src/Dovetail.d.ts
CHANGED
|
@@ -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
|
+
};
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useUIKit, pushModal, popModal } from '@cloudtower/eagle';
|
|
3
|
+
import { css } from '@linaria/core';
|
|
4
|
+
import { useCallback } from 'react';
|
|
5
|
+
import { FormErrorAlert } from 'src/components/FormErrorAlert';
|
|
6
|
+
import { useSubmitForm } from 'src/hooks/useSubmitForm';
|
|
7
|
+
import { useD2Translation } from '../../i18n';
|
|
8
|
+
const EditFieldModalStyle = css `
|
|
9
|
+
.ant-modal-content {
|
|
10
|
+
border-radius: 16px;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
.ant-modal-header {
|
|
14
|
+
border-radius: 16px 16px 0 0;
|
|
15
|
+
}
|
|
16
|
+
`;
|
|
17
|
+
const EditButtonStyle = css `
|
|
18
|
+
&.ant-btn.ant-btn-link {
|
|
19
|
+
height: 22px;
|
|
20
|
+
margin-left: 8px;
|
|
21
|
+
}
|
|
22
|
+
`;
|
|
23
|
+
export function EditFieldModal(props) {
|
|
24
|
+
const { title, formRef: form, renderContent } = props;
|
|
25
|
+
const kit = useUIKit();
|
|
26
|
+
const { i18n } = useD2Translation();
|
|
27
|
+
const { submitting, errorMsgs, reset, onSubmit, } = useSubmitForm({
|
|
28
|
+
formRef: form,
|
|
29
|
+
onSubmitSuccess: popModal
|
|
30
|
+
});
|
|
31
|
+
const close = useCallback(() => {
|
|
32
|
+
popModal();
|
|
33
|
+
reset();
|
|
34
|
+
}, [reset]);
|
|
35
|
+
return (_jsxs(kit.modal, { className: EditFieldModalStyle, title: title || i18n.t('dovetail.edit'), confirmLoading: submitting, onOk: onSubmit, onCancel: close, normal: true, destroyOnClose: true, children: [renderContent(), _jsx(FormErrorAlert, { style: { marginTop: 16 }, errorMsgs: errorMsgs })] }));
|
|
36
|
+
}
|
|
37
|
+
export function EditField(props) {
|
|
38
|
+
const { modalProps } = props;
|
|
39
|
+
const kit = useUIKit();
|
|
40
|
+
const { i18n } = useD2Translation();
|
|
41
|
+
return (_jsx(kit.button, { className: EditButtonStyle, type: "link", onClick: () => {
|
|
42
|
+
pushModal({
|
|
43
|
+
component: EditFieldModal,
|
|
44
|
+
props: modalProps
|
|
45
|
+
});
|
|
46
|
+
}, children: i18n.t('dovetail.edit') }));
|
|
47
|
+
}
|
|
@@ -1,10 +1,16 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
export declare const ErrorWrapper: import("@linaria/react").StyledComponent<React.ClassAttributes<HTMLDivElement> & React.HTMLAttributes<HTMLDivElement> & Record<never, unknown>>;
|
|
3
3
|
export declare const ErrorContent: import("@linaria/react").StyledComponent<React.ClassAttributes<HTMLDivElement> & React.HTMLAttributes<HTMLDivElement> & Record<never, unknown>>;
|
|
4
|
+
export declare enum ErrorContentType {
|
|
5
|
+
List = "list",
|
|
6
|
+
Card = "card",
|
|
7
|
+
Widget = "widget"
|
|
8
|
+
}
|
|
4
9
|
export type WidgetErrorContentProps = {
|
|
5
10
|
className?: string;
|
|
6
11
|
style?: React.CSSProperties;
|
|
7
12
|
errorText?: string;
|
|
13
|
+
type?: ErrorContentType;
|
|
8
14
|
refetch?: () => void;
|
|
9
15
|
};
|
|
10
16
|
declare const WidgetErrorContent: React.FunctionComponent<WidgetErrorContentProps>;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { kitContext, Typo } from '@cloudtower/eagle';
|
|
3
|
+
import { cx } from '@linaria/core';
|
|
4
|
+
import { styled } from '@linaria/react';
|
|
5
|
+
import { useContext } from 'react';
|
|
6
|
+
import { useD2Translation } from '../../i18n';
|
|
7
|
+
export const ErrorWrapper = styled.div `
|
|
8
|
+
display: flex;
|
|
9
|
+
flex-direction: column;
|
|
10
|
+
justify-content: center;
|
|
11
|
+
align-items: center;
|
|
12
|
+
height: 100%;
|
|
13
|
+
`;
|
|
14
|
+
export const ErrorContent = styled.div `
|
|
15
|
+
display: flex;
|
|
16
|
+
flex-direction: column;
|
|
17
|
+
align-items: center;
|
|
18
|
+
|
|
19
|
+
.title {
|
|
20
|
+
margin-bottom: 8px;
|
|
21
|
+
background-clip: text;
|
|
22
|
+
-webkit-background-clip: text;
|
|
23
|
+
-webkit-text-fill-color: transparent;
|
|
24
|
+
background-image: linear-gradient(211.41deg, #929dad 0%, #d3dbe3 100%);
|
|
25
|
+
}
|
|
26
|
+
`;
|
|
27
|
+
const WidgetErrorContent = props => {
|
|
28
|
+
const { refetch, errorText, hiddenRetry } = props;
|
|
29
|
+
const kit = useContext(kitContext);
|
|
30
|
+
const { t } = useD2Translation();
|
|
31
|
+
return (_jsx(ErrorWrapper, { className: props.className, style: props.style, children: _jsxs(ErrorContent, { children: [_jsx("p", { className: cx(Typo.Label.l1_regular_title, 'title'), children: errorText || t('dovetail.obtain_data_error') }), hiddenRetry ? null : (_jsx(kit.button, { size: "small", type: "ordinary", onClick: e => {
|
|
32
|
+
e.stopPropagation();
|
|
33
|
+
refetch?.();
|
|
34
|
+
}, children: t('dovetail.retry') }))] }) }));
|
|
35
|
+
};
|
|
36
|
+
export default WidgetErrorContent;
|