@digi-frontend/dgate-api-documentation 4.1.0 → 4.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -6783,7 +6783,7 @@ const TagsSection = ({ tags, collapsed, onToggleCollapse, onAddTag, onEditTag, o
6783
6783
  height: 32
6784
6784
  }),
6785
6785
  disabled: tag.isDefault,
6786
- onClick: () => !tag.isDefault && onDeleteTag?.(tag.name),
6786
+ onClick: () => !tag.isDefault && onDeleteTag?.(tag.name, tags.findIndex((t) => t.name === tag.name)),
6787
6787
  style: {
6788
6788
  width: 40,
6789
6789
  height: 40,
@@ -6959,7 +6959,7 @@ const TagsSection = ({ tags, collapsed, onToggleCollapse, onAddTag, onEditTag, o
6959
6959
  height: 32
6960
6960
  }),
6961
6961
  disabled: tag.isDefault,
6962
- onClick: () => !tag.isDefault && onDeleteTag?.(tag.name),
6962
+ onClick: () => !tag.isDefault && onDeleteTag?.(tag.name, tags.findIndex((t) => t.name === tag.name)),
6963
6963
  style: {
6964
6964
  width: 40,
6965
6965
  height: 40,
@@ -7002,7 +7002,7 @@ const TagsSection = ({ tags, collapsed, onToggleCollapse, onAddTag, onEditTag, o
7002
7002
  const TAG_NAME_REGEX = /^[A-Za-z0-9_\s-]+$/;
7003
7003
  const TAG_DESC_REGEX = /^[A-Za-z0-9_\s-]+$/;
7004
7004
  const EXTERNAL_DOCS_DESC_REGEX = /^[A-Za-z0-9_\s-]+$/;
7005
- const AddTagDrawer = ({ open, onClose, mode, initialValues, onAddTag, onEditTag }) => {
7005
+ const AddTagDrawer = ({ open, onClose, mode, initialValues, onAddTag, onEditTag, existingTags }) => {
7006
7006
  const [form] = antd.Form.useForm();
7007
7007
  const [messageApi, contextHolder] = antd.message.useMessage();
7008
7008
  const [confirmModalOpen, setConfirmModalOpen] = (0, react$1.useState)(false);
@@ -7133,7 +7133,7 @@ const AddTagDrawer = ({ open, onClose, mode, initialValues, onAddTag, onEditTag
7133
7133
  }
7134
7134
  }));
7135
7135
  const isLinkEnabled = Boolean(extDocsDesc?.trim());
7136
- const isAddEnabled = !!(tagNameValue && TAG_NAME_REGEX.test(tagNameValue));
7136
+ const isAddEnabled = !!(tagNameValue && TAG_NAME_REGEX.test(tagNameValue)) && !form.getFieldsError().some((field) => field.errors.length > 0);
7137
7137
  (0, react$1.useEffect)(() => {
7138
7138
  if (open && mode === "edit" && initialValues) form.setFieldsValue(initialValues);
7139
7139
  if (!open) form.resetFields();
@@ -7243,7 +7243,13 @@ const AddTagDrawer = ({ open, onClose, mode, initialValues, onAddTag, onEditTag
7243
7243
  {
7244
7244
  pattern: TAG_NAME_REGEX,
7245
7245
  message: "Only letters, numbers, spaces, underscores, and hyphens"
7246
- }
7246
+ },
7247
+ { validator: (_, value) => {
7248
+ if (!value || !existingTags?.length) return Promise.resolve();
7249
+ const originalName = initialValues?.name;
7250
+ if (existingTags.some((t) => t.name.toLowerCase() === value.toLowerCase() && t.name.toLowerCase() !== originalName?.toLowerCase())) return Promise.reject(/* @__PURE__ */ new Error("Tag name already exists"));
7251
+ return Promise.resolve();
7252
+ } }
7247
7253
  ],
7248
7254
  children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(antd.Input, {
7249
7255
  showCount: true,
@@ -8996,7 +9002,7 @@ const ConsoleDocumentationLayout = ({ data, preSelectedApi, handleVisitLandingPa
8996
9002
  });
8997
9003
  const [deleteTagModal, setDeleteTagModal] = (0, react$1.useState)({
8998
9004
  open: false,
8999
- tagName: ""
9005
+ tagIndex: -1
9000
9006
  });
9001
9007
  const [localTags, setLocalTags] = (0, react$1.useState)([]);
9002
9008
  const [messageApi, contextHolder] = antd.message.useMessage();
@@ -9173,7 +9179,9 @@ const ConsoleDocumentationLayout = ({ data, preSelectedApi, handleVisitLandingPa
9173
9179
  externalDocsDescription: t.externalDocs?.description,
9174
9180
  isDefault: t.name.toLowerCase() === "default"
9175
9181
  })) ?? [];
9176
- if (!mapped.some((t) => t.isDefault) && selectedApi.tags["default"]) mapped.push({
9182
+ const hasDefault = mapped.some((t) => t.isDefault);
9183
+ const hasDefaultInMapped = mapped.some((t) => t.name.toLowerCase() === "default");
9184
+ if (!hasDefault && !hasDefaultInMapped && selectedApi.tags["default"]) mapped.push({
9177
9185
  name: "default",
9178
9186
  isDefault: true
9179
9187
  });
@@ -9398,11 +9406,13 @@ const ConsoleDocumentationLayout = ({ data, preSelectedApi, handleVisitLandingPa
9398
9406
  setBannerVisible(true);
9399
9407
  };
9400
9408
  const handleDeleteTagConfirm = () => {
9401
- setLocalTags((prev) => prev.filter((t) => t.name !== deleteTagModal.tagName));
9402
- messageApi.success(`${deleteTagModal.tagName} tag has been deleted successfully.`);
9409
+ if (deleteTagModal.tagIndex < 0) return;
9410
+ const tagName = localTags[deleteTagModal.tagIndex]?.name ?? "Tag";
9411
+ setLocalTags((prev) => prev.filter((_, index) => index !== deleteTagModal.tagIndex));
9412
+ messageApi.success(`${tagName} tag has been deleted successfully.`);
9403
9413
  setDeleteTagModal({
9404
9414
  open: false,
9405
- tagName: ""
9415
+ tagIndex: -1
9406
9416
  });
9407
9417
  setBannerVisible(true);
9408
9418
  };
@@ -9801,9 +9811,9 @@ const ConsoleDocumentationLayout = ({ data, preSelectedApi, handleVisitLandingPa
9801
9811
  externalDocsLink: tag.externalDocsUrl
9802
9812
  }
9803
9813
  }),
9804
- onDeleteTag: (tagName) => setDeleteTagModal({
9814
+ onDeleteTag: (_tagName, tagIndex) => setDeleteTagModal({
9805
9815
  open: true,
9806
- tagName
9816
+ tagIndex
9807
9817
  })
9808
9818
  })
9809
9819
  }),
@@ -9963,9 +9973,9 @@ const ConsoleDocumentationLayout = ({ data, preSelectedApi, handleVisitLandingPa
9963
9973
  externalDocsLink: tag.externalDocsUrl
9964
9974
  }
9965
9975
  }),
9966
- onDeleteTag: (tagName) => setDeleteTagModal({
9976
+ onDeleteTag: (_tagName, tagIndex) => setDeleteTagModal({
9967
9977
  open: true,
9968
- tagName
9978
+ tagIndex
9969
9979
  })
9970
9980
  })
9971
9981
  }),
@@ -10093,7 +10103,8 @@ const ConsoleDocumentationLayout = ({ data, preSelectedApi, handleVisitLandingPa
10093
10103
  mode: "add"
10094
10104
  }),
10095
10105
  onAddTag: handleAddTag,
10096
- onEditTag: handleUpdateTag
10106
+ onEditTag: handleUpdateTag,
10107
+ existingTags: localTags
10097
10108
  }),
10098
10109
  /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(antd.Modal, {
10099
10110
  open: saveConfirmModal,
@@ -10237,7 +10248,7 @@ const ConsoleDocumentationLayout = ({ data, preSelectedApi, handleVisitLandingPa
10237
10248
  open: deleteTagModal.open,
10238
10249
  onCancel: () => setDeleteTagModal({
10239
10250
  open: false,
10240
- tagName: ""
10251
+ tagIndex: -1
10241
10252
  }),
10242
10253
  centered: true,
10243
10254
  title: null,
@@ -10263,14 +10274,14 @@ const ConsoleDocumentationLayout = ({ data, preSelectedApi, handleVisitLandingPa
10263
10274
  className: cx("deleteModalTitle"),
10264
10275
  children: [
10265
10276
  "Delete ",
10266
- deleteTagModal.tagName,
10277
+ localTags[deleteTagModal.tagIndex]?.name ?? "Tag",
10267
10278
  " tag"
10268
10279
  ]
10269
10280
  }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)("button", {
10270
10281
  className: cx("deleteModalCloseBtn"),
10271
10282
  onClick: () => setDeleteTagModal({
10272
10283
  open: false,
10273
- tagName: ""
10284
+ tagIndex: -1
10274
10285
  }),
10275
10286
  "aria-label": "Close",
10276
10287
  children: "×"
@@ -10282,7 +10293,7 @@ const ConsoleDocumentationLayout = ({ data, preSelectedApi, handleVisitLandingPa
10282
10293
  className: cx("deleteModalContentText"),
10283
10294
  children: [
10284
10295
  "Are you sure you want to delete ",
10285
- deleteTagModal.tagName,
10296
+ localTags[deleteTagModal.tagIndex]?.name ?? "Tag",
10286
10297
  " tag?"
10287
10298
  ]
10288
10299
  })
@@ -10293,7 +10304,7 @@ const ConsoleDocumentationLayout = ({ data, preSelectedApi, handleVisitLandingPa
10293
10304
  size: "middle",
10294
10305
  onClick: () => setDeleteTagModal({
10295
10306
  open: false,
10296
- tagName: ""
10307
+ tagIndex: -1
10297
10308
  }),
10298
10309
  style: {
10299
10310
  borderRadius: 8,