@dovetail-v2/refine 0.0.37-beta.0 → 0.0.37-bowen.0
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-c474875a.js} +1 -1
- package/dist/{index-1003469d.js → index-c2972aa1.js} +32 -12
- package/dist/refine.js +1 -1
- package/dist/refine.umd.cjs +31 -11
- 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/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.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 +6 -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 +2 -2
- 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
|
@@ -21652,6 +21652,11 @@ const RefineFormContent = (props) => {
|
|
|
21652
21652
|
meta: {}
|
|
21653
21653
|
});
|
|
21654
21654
|
}
|
|
21655
|
+
if (action === "edit" && c2.key === "name") {
|
|
21656
|
+
ele = /* @__PURE__ */ jsxRuntimeExports.jsx("div", {
|
|
21657
|
+
children: value2
|
|
21658
|
+
});
|
|
21659
|
+
}
|
|
21655
21660
|
return /* @__PURE__ */ jsxRuntimeExports.jsx(Form.Item, {
|
|
21656
21661
|
label: c2.label,
|
|
21657
21662
|
labelCol: {
|
|
@@ -22249,7 +22254,7 @@ const Separator = () => {
|
|
|
22249
22254
|
});
|
|
22250
22255
|
};
|
|
22251
22256
|
const MonacoYamlEditor = React__default.lazy(() => Promise.resolve().then(() => MonacoYamlEditor$2));
|
|
22252
|
-
const MonacoYamlDiffEditor = React__default.lazy(() => import("./MonacoYamlDiffEditor-
|
|
22257
|
+
const MonacoYamlDiffEditor = React__default.lazy(() => import("./MonacoYamlDiffEditor-c474875a.js"));
|
|
22253
22258
|
const YamlEditorComponent = forwardRef(
|
|
22254
22259
|
function YamlEditorComponent2(props, ref) {
|
|
22255
22260
|
const {
|
|
@@ -23084,14 +23089,26 @@ function ResourceForm(props) {
|
|
|
23084
23089
|
function ResourceCRUD(props) {
|
|
23085
23090
|
const { configs, urlPrefix } = props;
|
|
23086
23091
|
return /* @__PURE__ */ jsxRuntimeExports.jsx(jsxRuntimeExports.Fragment, { children: configs.map((config) => {
|
|
23087
|
-
var _a;
|
|
23092
|
+
var _a, _b, _c, _d, _e;
|
|
23088
23093
|
return /* @__PURE__ */ jsxRuntimeExports.jsxs(React__default.Fragment, { children: [
|
|
23089
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Route, { path: `${urlPrefix}/${config.name}`, exact: true, children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceList, { config }) }),
|
|
23090
|
-
!config.noShow ? /* @__PURE__ */ jsxRuntimeExports.jsx(Route, { path: `${urlPrefix}/${config.name}/show`, children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceShow, { config }) }) : null,
|
|
23094
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(Route, { path: ((_a = config.customPath) == null ? void 0 : _a.list) || `${urlPrefix}/${config.name}`, exact: true, children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceList, { config }) }),
|
|
23095
|
+
!config.noShow ? /* @__PURE__ */ jsxRuntimeExports.jsx(Route, { path: ((_b = config.customPath) == null ? void 0 : _b.show) || `${urlPrefix}/${config.name}/show`, children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceShow, { config }) }) : null,
|
|
23091
23096
|
// the modals would render in ModalStack
|
|
23092
|
-
((
|
|
23093
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
23094
|
-
|
|
23097
|
+
((_c = config.formConfig) == null ? void 0 : _c.formType) === FormType.PAGE ? /* @__PURE__ */ jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment, { children: [
|
|
23098
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
23099
|
+
Route,
|
|
23100
|
+
{
|
|
23101
|
+
path: ((_d = config.customPath) == null ? void 0 : _d.create) || `${urlPrefix}/${config.name}/create`,
|
|
23102
|
+
children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceForm, { config })
|
|
23103
|
+
}
|
|
23104
|
+
),
|
|
23105
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
23106
|
+
Route,
|
|
23107
|
+
{
|
|
23108
|
+
path: ((_e = config.customPath) == null ? void 0 : _e.edit) || `${urlPrefix}/${config.name}/edit`,
|
|
23109
|
+
children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceForm, { config })
|
|
23110
|
+
}
|
|
23111
|
+
)
|
|
23095
23112
|
] }) : null
|
|
23096
23113
|
] }, config.name);
|
|
23097
23114
|
}) });
|
|
@@ -23710,7 +23727,9 @@ function ServiceOutClusterAccessTitle() {
|
|
|
23710
23727
|
i18nKey: "dovetail.out_cluster_lb_desc"
|
|
23711
23728
|
})
|
|
23712
23729
|
}), /* @__PURE__ */ jsxRuntimeExports.jsx("div", {
|
|
23713
|
-
children:
|
|
23730
|
+
children: /* @__PURE__ */ jsxRuntimeExports.jsx(Trans, {
|
|
23731
|
+
i18nKey: "dovetail.out_external_name_desc"
|
|
23732
|
+
})
|
|
23714
23733
|
})]
|
|
23715
23734
|
}),
|
|
23716
23735
|
children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", {
|
|
@@ -24034,6 +24053,7 @@ const Dovetail = (props) => {
|
|
|
24034
24053
|
},
|
|
24035
24054
|
accessControlProvider,
|
|
24036
24055
|
resources: resourcesConfig.map((c2) => {
|
|
24056
|
+
var _a, _b, _c, _d;
|
|
24037
24057
|
return {
|
|
24038
24058
|
name: c2.name,
|
|
24039
24059
|
meta: {
|
|
@@ -24042,10 +24062,10 @@ const Dovetail = (props) => {
|
|
|
24042
24062
|
parent: c2.parent,
|
|
24043
24063
|
label: `${c2.kind}s`
|
|
24044
24064
|
},
|
|
24045
|
-
list: `${urlPrefix}/${c2.name}`,
|
|
24046
|
-
show: `${urlPrefix}/${c2.name}/show`,
|
|
24047
|
-
create: `${urlPrefix}/${c2.name}/create`,
|
|
24048
|
-
edit: `${urlPrefix}/${c2.name}/edit`
|
|
24065
|
+
list: ((_a = c2.customPath) == null ? void 0 : _a.list) || `${urlPrefix}/${c2.name}`,
|
|
24066
|
+
show: ((_b = c2.customPath) == null ? void 0 : _b.show) || `${urlPrefix}/${c2.name}/show`,
|
|
24067
|
+
create: ((_c = c2.customPath) == null ? void 0 : _c.create) || `${urlPrefix}/${c2.name}/create`,
|
|
24068
|
+
edit: ((_d = c2.customPath) == null ? void 0 : _d.edit) || `${urlPrefix}/${c2.name}/edit`
|
|
24049
24069
|
};
|
|
24050
24070
|
}),
|
|
24051
24071
|
children: content
|
package/dist/refine.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { b5, bJ, A, ay, aA, ai, bl, aI, G, bz, bn, as, w, C, g, bN, al, aM, X, bP, $, a6, bY, aa, bo, bm, b$, ao, aS, t, ag, aX, b_, bK, a$, D, aF, b1, bZ, aG, aw, b8, bM, bO, bx, aj, a0, p, o, bQ, I, aP, av, q, bp, bS, an, aO, ab, ac, Q, ad, az, ah, aY, b0, T, by, b4, N, H, b, ax, M, b7, aU, aT, bR, bj, e, br, U, P, aK, s, Y, bi, aH, bW, bV, aD, aQ, n, am, aJ, v, aR, aE, c3, bL, b2, b9, ba, ak, R, _, a4, a3, b3, a1, bX, a2, a7, f, bE, bH, bD, bC, bF, bG, bA, bs, bv, bw, bu, bt, bq, bb, ap, aN, ae, k, be, i, aB, c2, m, bf, aC, l, au, aL, h, c1, ar, at, aW, aV, aq, S, a_, aZ, c0, bB, bk, bg, bh, V, bU, Z, W, bT, a5, a9, a8, c, bI, af, bc, x, J, d, O, L, K, r, a, z, y, B, E, b6, F, bd, u } from "./index-
|
|
1
|
+
import { b5, bJ, A, ay, aA, ai, bl, aI, G, bz, bn, as, w, C, g, bN, al, aM, X, bP, $, a6, bY, aa, bo, bm, b$, ao, aS, t, ag, aX, b_, bK, a$, D, aF, b1, bZ, aG, aw, b8, bM, bO, bx, aj, a0, p, o, bQ, I, aP, av, q, bp, bS, an, aO, ab, ac, Q, ad, az, ah, aY, b0, T, by, b4, N, H, b, ax, M, b7, aU, aT, bR, bj, e, br, U, P, aK, s, Y, bi, aH, bW, bV, aD, aQ, n, am, aJ, v, aR, aE, c3, bL, b2, b9, ba, ak, R, _, a4, a3, b3, a1, bX, a2, a7, f, bE, bH, bD, bC, bF, bG, bA, bs, bv, bw, bu, bt, bq, bb, ap, aN, ae, k, be, i, aB, c2, m, bf, aC, l, au, aL, h, c1, ar, at, aW, aV, aq, S, a_, aZ, c0, bB, bk, bg, bh, V, bU, Z, W, bT, a5, a9, a8, c, bI, af, bc, x, J, d, O, L, K, r, a, z, y, B, E, b6, F, bd, u } from "./index-c2972aa1.js";
|
|
2
2
|
import "@cloudtower/eagle";
|
|
3
3
|
import "@refinedev/core";
|
|
4
4
|
import "@cloudtower/icons-react";
|
package/dist/refine.umd.cjs
CHANGED
|
@@ -21658,6 +21658,11 @@ var __publicField = (obj, key, value) => {
|
|
|
21658
21658
|
meta: {}
|
|
21659
21659
|
});
|
|
21660
21660
|
}
|
|
21661
|
+
if (action === "edit" && c2.key === "name") {
|
|
21662
|
+
ele = /* @__PURE__ */ jsxRuntimeExports.jsx("div", {
|
|
21663
|
+
children: value2
|
|
21664
|
+
});
|
|
21665
|
+
}
|
|
21661
21666
|
return /* @__PURE__ */ jsxRuntimeExports.jsx(eagle.Form.Item, {
|
|
21662
21667
|
label: c2.label,
|
|
21663
21668
|
labelCol: {
|
|
@@ -23090,14 +23095,26 @@ var __publicField = (obj, key, value) => {
|
|
|
23090
23095
|
function ResourceCRUD(props) {
|
|
23091
23096
|
const { configs, urlPrefix } = props;
|
|
23092
23097
|
return /* @__PURE__ */ jsxRuntimeExports.jsx(jsxRuntimeExports.Fragment, { children: configs.map((config) => {
|
|
23093
|
-
var _a;
|
|
23098
|
+
var _a, _b, _c, _d, _e;
|
|
23094
23099
|
return /* @__PURE__ */ jsxRuntimeExports.jsxs(React.Fragment, { children: [
|
|
23095
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(reactRouterDom.Route, { path: `${urlPrefix}/${config.name}`, exact: true, children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceList, { config }) }),
|
|
23096
|
-
!config.noShow ? /* @__PURE__ */ jsxRuntimeExports.jsx(reactRouterDom.Route, { path: `${urlPrefix}/${config.name}/show`, children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceShow, { config }) }) : null,
|
|
23100
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(reactRouterDom.Route, { path: ((_a = config.customPath) == null ? void 0 : _a.list) || `${urlPrefix}/${config.name}`, exact: true, children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceList, { config }) }),
|
|
23101
|
+
!config.noShow ? /* @__PURE__ */ jsxRuntimeExports.jsx(reactRouterDom.Route, { path: ((_b = config.customPath) == null ? void 0 : _b.show) || `${urlPrefix}/${config.name}/show`, children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceShow, { config }) }) : null,
|
|
23097
23102
|
// the modals would render in ModalStack
|
|
23098
|
-
((
|
|
23099
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
23100
|
-
|
|
23103
|
+
((_c = config.formConfig) == null ? void 0 : _c.formType) === FormType.PAGE ? /* @__PURE__ */ jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment, { children: [
|
|
23104
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
23105
|
+
reactRouterDom.Route,
|
|
23106
|
+
{
|
|
23107
|
+
path: ((_d = config.customPath) == null ? void 0 : _d.create) || `${urlPrefix}/${config.name}/create`,
|
|
23108
|
+
children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceForm, { config })
|
|
23109
|
+
}
|
|
23110
|
+
),
|
|
23111
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
23112
|
+
reactRouterDom.Route,
|
|
23113
|
+
{
|
|
23114
|
+
path: ((_e = config.customPath) == null ? void 0 : _e.edit) || `${urlPrefix}/${config.name}/edit`,
|
|
23115
|
+
children: /* @__PURE__ */ jsxRuntimeExports.jsx(ResourceForm, { config })
|
|
23116
|
+
}
|
|
23117
|
+
)
|
|
23101
23118
|
] }) : null
|
|
23102
23119
|
] }, config.name);
|
|
23103
23120
|
}) });
|
|
@@ -23716,7 +23733,9 @@ var __publicField = (obj, key, value) => {
|
|
|
23716
23733
|
i18nKey: "dovetail.out_cluster_lb_desc"
|
|
23717
23734
|
})
|
|
23718
23735
|
}), /* @__PURE__ */ jsxRuntimeExports.jsx("div", {
|
|
23719
|
-
children:
|
|
23736
|
+
children: /* @__PURE__ */ jsxRuntimeExports.jsx(Trans, {
|
|
23737
|
+
i18nKey: "dovetail.out_external_name_desc"
|
|
23738
|
+
})
|
|
23720
23739
|
})]
|
|
23721
23740
|
}),
|
|
23722
23741
|
children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", {
|
|
@@ -24040,6 +24059,7 @@ var __publicField = (obj, key, value) => {
|
|
|
24040
24059
|
},
|
|
24041
24060
|
accessControlProvider,
|
|
24042
24061
|
resources: resourcesConfig.map((c2) => {
|
|
24062
|
+
var _a, _b, _c, _d;
|
|
24043
24063
|
return {
|
|
24044
24064
|
name: c2.name,
|
|
24045
24065
|
meta: {
|
|
@@ -24048,10 +24068,10 @@ var __publicField = (obj, key, value) => {
|
|
|
24048
24068
|
parent: c2.parent,
|
|
24049
24069
|
label: `${c2.kind}s`
|
|
24050
24070
|
},
|
|
24051
|
-
list: `${urlPrefix}/${c2.name}`,
|
|
24052
|
-
show: `${urlPrefix}/${c2.name}/show`,
|
|
24053
|
-
create: `${urlPrefix}/${c2.name}/create`,
|
|
24054
|
-
edit: `${urlPrefix}/${c2.name}/edit`
|
|
24071
|
+
list: ((_a = c2.customPath) == null ? void 0 : _a.list) || `${urlPrefix}/${c2.name}`,
|
|
24072
|
+
show: ((_b = c2.customPath) == null ? void 0 : _b.show) || `${urlPrefix}/${c2.name}/show`,
|
|
24073
|
+
create: ((_c = c2.customPath) == null ? void 0 : _c.create) || `${urlPrefix}/${c2.name}/create`,
|
|
24074
|
+
edit: ((_d = c2.customPath) == null ? void 0 : _d.edit) || `${urlPrefix}/${c2.name}/edit`
|
|
24055
24075
|
};
|
|
24056
24076
|
}),
|
|
24057
24077
|
children: content
|
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
|
+
};
|
|
@@ -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
|
+
}
|
|
@@ -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;
|