@yibozhang/pro-table 0.1.6 → 0.1.8

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.
@@ -0,0 +1,176 @@
1
+ /**
2
+ * 自动检测 nz-select 最近的父元素宽度,并设置给 nz-select
3
+ * 当父元素宽度变化时,自动更新 nz-select 的宽度
4
+ */
5
+ export function initSelectWidthDetector() {
6
+ if (typeof window === 'undefined' || typeof document === 'undefined') {
7
+ return;
8
+ }
9
+ // 获取最近的父元素(排除自身)
10
+ function getClosestParent(element) {
11
+ let parent = element.parentElement;
12
+ while (parent && parent !== document.body) {
13
+ // 如果父元素有明确的宽度(非 auto),则返回该父元素
14
+ const computedStyle = window.getComputedStyle(parent);
15
+ const width = computedStyle.width;
16
+ if (width && width !== 'auto' && width !== '0px') {
17
+ return parent;
18
+ }
19
+ parent = parent.parentElement;
20
+ }
21
+ // 如果没找到有明确宽度的父元素,返回直接父元素
22
+ return element.parentElement;
23
+ }
24
+ // 找到实际的 select 元素(nz-select 组件渲染后的 DOM 元素)
25
+ function findActualSelectElement(element) {
26
+ var _a;
27
+ // 如果已经是 ant-select 元素,直接返回
28
+ if ((_a = element.classList) === null || _a === void 0 ? void 0 : _a.contains('ant-select')) {
29
+ return element;
30
+ }
31
+ // 如果是 nz-select 组件标签,查找其渲染后的 ant-select 元素
32
+ if (element.tagName === 'NZ-SELECT') {
33
+ const actualSelect = element.querySelector('.ant-select');
34
+ return actualSelect || element;
35
+ }
36
+ // 在子元素中查找 ant-select
37
+ const actualSelect = element.querySelector('.ant-select');
38
+ return actualSelect || element;
39
+ }
40
+ // 获取原始的 nz-select 组件元素(用于读取 custom-width 属性)
41
+ function getOriginalSelectElement(element) {
42
+ // 如果已经是 nz-select 组件标签,直接返回
43
+ if (element.tagName === 'NZ-SELECT') {
44
+ return element;
45
+ }
46
+ // 向上查找 nz-select 组件标签
47
+ let parent = element.parentElement;
48
+ while (parent && parent !== document.body) {
49
+ if (parent.tagName === 'NZ-SELECT') {
50
+ return parent;
51
+ }
52
+ parent = parent.parentElement;
53
+ }
54
+ return null;
55
+ }
56
+ // 检查并设置 nz-select 的宽度
57
+ function setSelectWidth(selectElement) {
58
+ const actualSelect = findActualSelectElement(selectElement);
59
+ if (!actualSelect) {
60
+ return;
61
+ }
62
+ // 检查是否有自定义宽度属性
63
+ const originalSelect = getOriginalSelectElement(selectElement);
64
+ if (originalSelect) {
65
+ const customWidth = originalSelect.getAttribute('custom-width');
66
+ if (customWidth) {
67
+ // 使用自定义宽度
68
+ actualSelect.style.width = customWidth;
69
+ return;
70
+ }
71
+ }
72
+ // 如果没有自定义宽度,使用计算出的父元素宽度
73
+ const parent = getClosestParent(actualSelect);
74
+ if (parent) {
75
+ const parentWidth = parent.offsetWidth;
76
+ if (parentWidth > 0) {
77
+ // 设置宽度,可以减去一些 padding/margin 来避免溢出
78
+ // 这里直接使用父元素宽度,如果需要可以调整
79
+ actualSelect.style.width = `${parentWidth}px`;
80
+ }
81
+ }
82
+ }
83
+ // 使用 MutationObserver 监听 DOM 变化
84
+ const observer = new MutationObserver((mutations) => {
85
+ mutations.forEach((mutation) => {
86
+ mutation.addedNodes.forEach((node) => {
87
+ var _a, _b, _c;
88
+ if (node.nodeType === Node.ELEMENT_NODE) {
89
+ const element = node;
90
+ // 检查是否是 nz-select 组件标签
91
+ if (element.tagName === 'NZ-SELECT') {
92
+ // 等待 Angular 组件渲染完成
93
+ setTimeout(() => {
94
+ setSelectWidth(element);
95
+ observeResize(element);
96
+ }, 100);
97
+ }
98
+ // 检查是否是 ant-select 元素(nz-select 渲染后的实际元素)
99
+ if ((_a = element.classList) === null || _a === void 0 ? void 0 : _a.contains('ant-select')) {
100
+ setTimeout(() => {
101
+ setSelectWidth(element);
102
+ observeResize(element);
103
+ }, 0);
104
+ }
105
+ // 检查子元素中是否有 nz-select 或 ant-select
106
+ const nzSelects = (_b = element.querySelectorAll) === null || _b === void 0 ? void 0 : _b.call(element, 'nz-select');
107
+ nzSelects === null || nzSelects === void 0 ? void 0 : nzSelects.forEach((select) => {
108
+ setTimeout(() => {
109
+ setSelectWidth(select);
110
+ observeResize(select);
111
+ }, 100);
112
+ });
113
+ const antSelects = (_c = element.querySelectorAll) === null || _c === void 0 ? void 0 : _c.call(element, '.ant-select');
114
+ antSelects === null || antSelects === void 0 ? void 0 : antSelects.forEach((select) => {
115
+ setTimeout(() => {
116
+ setSelectWidth(select);
117
+ observeResize(select);
118
+ }, 0);
119
+ });
120
+ }
121
+ });
122
+ });
123
+ });
124
+ // 使用 ResizeObserver 监听父元素尺寸变化
125
+ const resizeObserverMap = new WeakMap();
126
+ function observeResize(selectElement) {
127
+ if (resizeObserverMap.has(selectElement)) {
128
+ return;
129
+ }
130
+ if (typeof window.ResizeObserver !== 'undefined') {
131
+ const actualSelect = findActualSelectElement(selectElement);
132
+ if (!actualSelect) {
133
+ return;
134
+ }
135
+ const parent = getClosestParent(actualSelect);
136
+ if (!parent) {
137
+ return;
138
+ }
139
+ const resizeObserver = new window.ResizeObserver(() => {
140
+ setSelectWidth(selectElement);
141
+ });
142
+ resizeObserver.observe(parent);
143
+ resizeObserverMap.set(selectElement, resizeObserver);
144
+ }
145
+ }
146
+ // 开始监听 DOM 变化
147
+ observer.observe(document.body, {
148
+ childList: true,
149
+ subtree: true,
150
+ });
151
+ // 检查已存在的 nz-select 和 ant-select
152
+ const checkExistingSelects = () => {
153
+ // 检查 nz-select 组件标签
154
+ document.querySelectorAll('nz-select').forEach((element) => {
155
+ setTimeout(() => {
156
+ setSelectWidth(element);
157
+ observeResize(element);
158
+ }, 100);
159
+ });
160
+ // 检查 ant-select 元素
161
+ document.querySelectorAll('.ant-select').forEach((element) => {
162
+ setTimeout(() => {
163
+ setSelectWidth(element);
164
+ observeResize(element);
165
+ }, 0);
166
+ });
167
+ };
168
+ // 延迟执行,确保 DOM 已完全加载
169
+ if (document.readyState === 'loading') {
170
+ document.addEventListener('DOMContentLoaded', checkExistingSelects);
171
+ }
172
+ else {
173
+ checkExistingSelects();
174
+ }
175
+ }
176
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-width-detector.js","sourceRoot":"D:/projects/vps-front/Front/DasPMSWeb/lib/pro-table/src/","sources":["lib/utils/select-width-detector.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * 自动检测 nz-select 最近的父元素宽度，并设置给 nz-select\r\n * 当父元素宽度变化时，自动更新 nz-select 的宽度\r\n */\r\nexport function initSelectWidthDetector() {\r\n  if (typeof window === 'undefined' || typeof document === 'undefined') {\r\n    return;\r\n  }\r\n\r\n  // 获取最近的父元素（排除自身）\r\n  function getClosestParent(element: HTMLElement): HTMLElement | null {\r\n    let parent = element.parentElement;\r\n    while (parent && parent !== document.body) {\r\n      // 如果父元素有明确的宽度（非 auto），则返回该父元素\r\n      const computedStyle = window.getComputedStyle(parent);\r\n      const width = computedStyle.width;\r\n      if (width && width !== 'auto' && width !== '0px') {\r\n        return parent;\r\n      }\r\n      parent = parent.parentElement;\r\n    }\r\n    // 如果没找到有明确宽度的父元素，返回直接父元素\r\n    return element.parentElement;\r\n  }\r\n\r\n  // 找到实际的 select 元素（nz-select 组件渲染后的 DOM 元素）\r\n  function findActualSelectElement(element: HTMLElement): HTMLElement | null {\r\n    // 如果已经是 ant-select 元素，直接返回\r\n    if (element.classList?.contains('ant-select')) {\r\n      return element;\r\n    }\r\n    \r\n    // 如果是 nz-select 组件标签，查找其渲染后的 ant-select 元素\r\n    if (element.tagName === 'NZ-SELECT') {\r\n      const actualSelect = element.querySelector('.ant-select') as HTMLElement;\r\n      return actualSelect || element;\r\n    }\r\n    \r\n    // 在子元素中查找 ant-select\r\n    const actualSelect = element.querySelector('.ant-select') as HTMLElement;\r\n    return actualSelect || element;\r\n  }\r\n\r\n  // 获取原始的 nz-select 组件元素（用于读取 custom-width 属性）\r\n  function getOriginalSelectElement(element: HTMLElement): HTMLElement | null {\r\n    // 如果已经是 nz-select 组件标签，直接返回\r\n    if (element.tagName === 'NZ-SELECT') {\r\n      return element;\r\n    }\r\n    \r\n    // 向上查找 nz-select 组件标签\r\n    let parent = element.parentElement;\r\n    while (parent && parent !== document.body) {\r\n      if (parent.tagName === 'NZ-SELECT') {\r\n        return parent;\r\n      }\r\n      parent = parent.parentElement;\r\n    }\r\n    \r\n    return null;\r\n  }\r\n\r\n  // 检查并设置 nz-select 的宽度\r\n  function setSelectWidth(selectElement: HTMLElement) {\r\n    const actualSelect = findActualSelectElement(selectElement);\r\n    if (!actualSelect) {\r\n      return;\r\n    }\r\n\r\n    // 检查是否有自定义宽度属性\r\n    const originalSelect = getOriginalSelectElement(selectElement);\r\n    if (originalSelect) {\r\n      const customWidth = originalSelect.getAttribute('custom-width');\r\n      if (customWidth) {\r\n        // 使用自定义宽度\r\n        actualSelect.style.width = customWidth;\r\n        return;\r\n      }\r\n    }\r\n\r\n    // 如果没有自定义宽度，使用计算出的父元素宽度\r\n    const parent = getClosestParent(actualSelect);\r\n    if (parent) {\r\n      const parentWidth = parent.offsetWidth;\r\n      if (parentWidth > 0) {\r\n        // 设置宽度，可以减去一些 padding/margin 来避免溢出\r\n        // 这里直接使用父元素宽度，如果需要可以调整\r\n        actualSelect.style.width = `${parentWidth}px`;\r\n      }\r\n    }\r\n  }\r\n\r\n  // 使用 MutationObserver 监听 DOM 变化\r\n  const observer = new MutationObserver((mutations) => {\r\n    mutations.forEach((mutation) => {\r\n      mutation.addedNodes.forEach((node) => {\r\n        if (node.nodeType === Node.ELEMENT_NODE) {\r\n          const element = node as HTMLElement;\r\n          \r\n          // 检查是否是 nz-select 组件标签\r\n          if (element.tagName === 'NZ-SELECT') {\r\n            // 等待 Angular 组件渲染完成\r\n            setTimeout(() => {\r\n              setSelectWidth(element);\r\n              observeResize(element);\r\n            }, 100);\r\n          }\r\n          \r\n          // 检查是否是 ant-select 元素（nz-select 渲染后的实际元素）\r\n          if (element.classList?.contains('ant-select')) {\r\n            setTimeout(() => {\r\n              setSelectWidth(element);\r\n              observeResize(element);\r\n            }, 0);\r\n          }\r\n          \r\n          // 检查子元素中是否有 nz-select 或 ant-select\r\n          const nzSelects = element.querySelectorAll?.('nz-select');\r\n          nzSelects?.forEach((select) => {\r\n            setTimeout(() => {\r\n              setSelectWidth(select as HTMLElement);\r\n              observeResize(select as HTMLElement);\r\n            }, 100);\r\n          });\r\n          \r\n          const antSelects = element.querySelectorAll?.('.ant-select');\r\n          antSelects?.forEach((select) => {\r\n            setTimeout(() => {\r\n              setSelectWidth(select as HTMLElement);\r\n              observeResize(select as HTMLElement);\r\n            }, 0);\r\n          });\r\n        }\r\n      });\r\n    });\r\n  });\r\n\r\n  // 使用 ResizeObserver 监听父元素尺寸变化\r\n  const resizeObserverMap = new WeakMap<HTMLElement, any>();\r\n  \r\n  function observeResize(selectElement: HTMLElement) {\r\n    if (resizeObserverMap.has(selectElement)) {\r\n      return;\r\n    }\r\n\r\n    if (typeof (window as any).ResizeObserver !== 'undefined') {\r\n      const actualSelect = findActualSelectElement(selectElement);\r\n      if (!actualSelect) {\r\n        return;\r\n      }\r\n\r\n      const parent = getClosestParent(actualSelect);\r\n      if (!parent) {\r\n        return;\r\n      }\r\n\r\n      const resizeObserver = new (window as any).ResizeObserver(() => {\r\n        setSelectWidth(selectElement);\r\n      });\r\n      resizeObserver.observe(parent);\r\n      resizeObserverMap.set(selectElement, resizeObserver);\r\n    }\r\n  }\r\n\r\n  // 开始监听 DOM 变化\r\n  observer.observe(document.body, {\r\n    childList: true,\r\n    subtree: true,\r\n  });\r\n\r\n  // 检查已存在的 nz-select 和 ant-select\r\n  const checkExistingSelects = () => {\r\n    // 检查 nz-select 组件标签\r\n    document.querySelectorAll('nz-select').forEach((element) => {\r\n      setTimeout(() => {\r\n        setSelectWidth(element as HTMLElement);\r\n        observeResize(element as HTMLElement);\r\n      }, 100);\r\n    });\r\n    \r\n    // 检查 ant-select 元素\r\n    document.querySelectorAll('.ant-select').forEach((element) => {\r\n      setTimeout(() => {\r\n        setSelectWidth(element as HTMLElement);\r\n        observeResize(element as HTMLElement);\r\n      }, 0);\r\n    });\r\n  };\r\n\r\n  // 延迟执行，确保 DOM 已完全加载\r\n  if (document.readyState === 'loading') {\r\n    document.addEventListener('DOMContentLoaded', checkExistingSelects);\r\n  } else {\r\n    checkExistingSelects();\r\n  }\r\n}\r\n"]}
@@ -17,4 +17,5 @@ export { AntdFormService } from "./lib/page-public/antd-form";
17
17
  export { ArrayFormService } from "./lib/page-public/array-form";
18
18
  // Export modal width detector
19
19
  export { initModalWidthDetector } from "./lib/utils/modal-width-detector";
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJEOi9wcm9qZWN0cy92cHMtZnJvbnQvRnJvbnQvRGFzUE1TV2ViL2xpYi9wcm8tdGFibGUvc3JjLyIsInNvdXJjZXMiOlsicHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxvQ0FBb0MsQ0FBQztBQUVuRCxxQ0FBcUM7QUFDckMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBYzlELHNDQUFzQztBQUN0QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQVdoRSw4QkFBOEI7QUFDOUIsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sa0NBQWtDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgcHJvLXRhYmxlXHJcbiAqL1xyXG5cclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3Byby10YWJsZS5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3Byby10YWJsZS5tb2R1bGVcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbnN0YW50c1wiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvdHlwZVwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvdG9rZW5zXCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9wbGF0ZS1pbnB1dC9wbGF0ZS1wcmVmaXgtbG9hZC5zZXJ2aWNlXCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9wbGF0ZS1pbnB1dC9wbGF0ZS1pbnB1dC5tb2R1bGVcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3BhZ2UtY29udGFpbmVyL3BhZ2UtY29udGFpbmVyLm1vZHVsZVwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvdGFibGUtc2VhcmNoLWJhci90YWJsZS1zZWFyY2gtYmFyLW1vZHVsZVwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvZGlyZWN0aXZlcy90cmltLWlucHV0Lm1vZHVsZVwiO1xyXG5cclxuLy8gRXhwb3J0IGFudGQtZm9ybSBzZXJ2aWNlIGFuZCB0eXBlc1xyXG5leHBvcnQgeyBBbnRkRm9ybVNlcnZpY2UgfSBmcm9tIFwiLi9saWIvcGFnZS1wdWJsaWMvYW50ZC1mb3JtXCI7XHJcbmV4cG9ydCB0eXBlIHtcclxuICBGaWVsZEVycm9yTWVzc2FnZSxcclxuICBGaWVsZEVycm9yTWVzc2FnZXMsXHJcbiAgRmllbGRDb25maWcsXHJcbiAgRm9ybU1vZGlmeVR5cGUsXHJcbiAgRm9ybUNvbmZpZyxcclxuICBXYXRjaE9wdGlvbnMsXHJcbiAgQWRkRmllbGRzQ29uZmlnT3B0aW9ucyxcclxuICBBZGRGaWVsZHNDb25maWdSZXN1bHQsXHJcbiAgUmVtb3ZlRmllbGRzQ29uZmlnT3B0aW9ucyxcclxuICBSZW1vdmVGaWVsZHNDb25maWdSZXN1bHQsXHJcbn0gZnJvbSBcIi4vbGliL3BhZ2UtcHVibGljL2FudGQtZm9ybVwiO1xyXG5cclxuLy8gRXhwb3J0IGFycmF5LWZvcm0gc2VydmljZSBhbmQgdHlwZXNcclxuZXhwb3J0IHsgQXJyYXlGb3JtU2VydmljZSB9IGZyb20gXCIuL2xpYi9wYWdlLXB1YmxpYy9hcnJheS1mb3JtXCI7XHJcbmV4cG9ydCB0eXBlIHtcclxuICBWYWxpZGF0aW9uUmVzdWx0LFxyXG4gIEZpZWxkVmFsaWRhdG9yLFxyXG4gIEZpZWxkQ29uZmlnIGFzIEFycmF5RmllbGRDb25maWcsXHJcbiAgQXJyYXlGb3JtUm93LFxyXG4gIEFycmF5Rm9ybUNvbmZpZyxcclxuICBBcnJheUZvcm1TdG9yZUl0ZW0sXHJcbiAgQXJyYXlGb3JtU3RvcmUsXHJcbn0gZnJvbSBcIi4vbGliL3BhZ2UtcHVibGljL2FycmF5LWZvcm1cIjtcclxuXHJcbi8vIEV4cG9ydCBtb2RhbCB3aWR0aCBkZXRlY3RvclxyXG5leHBvcnQgeyBpbml0TW9kYWxXaWR0aERldGVjdG9yIH0gZnJvbSBcIi4vbGliL3V0aWxzL21vZGFsLXdpZHRoLWRldGVjdG9yXCI7XHJcbiJdfQ==
20
+ export { initSelectWidthDetector } from "./lib/utils/select-width-detector";
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJEOi9wcm9qZWN0cy92cHMtZnJvbnQvRnJvbnQvRGFzUE1TV2ViL2xpYi9wcm8tdGFibGUvc3JjLyIsInNvdXJjZXMiOlsicHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxvQ0FBb0MsQ0FBQztBQUVuRCxxQ0FBcUM7QUFDckMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBYzlELHNDQUFzQztBQUN0QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQVdoRSw4QkFBOEI7QUFDOUIsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDMUUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sbUNBQW1DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgcHJvLXRhYmxlXHJcbiAqL1xyXG5cclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3Byby10YWJsZS5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3Byby10YWJsZS5tb2R1bGVcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NvbnN0YW50c1wiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvdHlwZVwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvdG9rZW5zXCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9wbGF0ZS1pbnB1dC9wbGF0ZS1wcmVmaXgtbG9hZC5zZXJ2aWNlXCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9wbGF0ZS1pbnB1dC9wbGF0ZS1pbnB1dC5tb2R1bGVcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3BhZ2UtY29udGFpbmVyL3BhZ2UtY29udGFpbmVyLm1vZHVsZVwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvdGFibGUtc2VhcmNoLWJhci90YWJsZS1zZWFyY2gtYmFyLW1vZHVsZVwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvZGlyZWN0aXZlcy90cmltLWlucHV0Lm1vZHVsZVwiO1xyXG5cclxuLy8gRXhwb3J0IGFudGQtZm9ybSBzZXJ2aWNlIGFuZCB0eXBlc1xyXG5leHBvcnQgeyBBbnRkRm9ybVNlcnZpY2UgfSBmcm9tIFwiLi9saWIvcGFnZS1wdWJsaWMvYW50ZC1mb3JtXCI7XHJcbmV4cG9ydCB0eXBlIHtcclxuICBGaWVsZEVycm9yTWVzc2FnZSxcclxuICBGaWVsZEVycm9yTWVzc2FnZXMsXHJcbiAgRmllbGRDb25maWcsXHJcbiAgRm9ybU1vZGlmeVR5cGUsXHJcbiAgRm9ybUNvbmZpZyxcclxuICBXYXRjaE9wdGlvbnMsXHJcbiAgQWRkRmllbGRzQ29uZmlnT3B0aW9ucyxcclxuICBBZGRGaWVsZHNDb25maWdSZXN1bHQsXHJcbiAgUmVtb3ZlRmllbGRzQ29uZmlnT3B0aW9ucyxcclxuICBSZW1vdmVGaWVsZHNDb25maWdSZXN1bHQsXHJcbn0gZnJvbSBcIi4vbGliL3BhZ2UtcHVibGljL2FudGQtZm9ybVwiO1xyXG5cclxuLy8gRXhwb3J0IGFycmF5LWZvcm0gc2VydmljZSBhbmQgdHlwZXNcclxuZXhwb3J0IHsgQXJyYXlGb3JtU2VydmljZSB9IGZyb20gXCIuL2xpYi9wYWdlLXB1YmxpYy9hcnJheS1mb3JtXCI7XHJcbmV4cG9ydCB0eXBlIHtcclxuICBWYWxpZGF0aW9uUmVzdWx0LFxyXG4gIEZpZWxkVmFsaWRhdG9yLFxyXG4gIEZpZWxkQ29uZmlnIGFzIEFycmF5RmllbGRDb25maWcsXHJcbiAgQXJyYXlGb3JtUm93LFxyXG4gIEFycmF5Rm9ybUNvbmZpZyxcclxuICBBcnJheUZvcm1TdG9yZUl0ZW0sXHJcbiAgQXJyYXlGb3JtU3RvcmUsXHJcbn0gZnJvbSBcIi4vbGliL3BhZ2UtcHVibGljL2FycmF5LWZvcm1cIjtcclxuXHJcbi8vIEV4cG9ydCBtb2RhbCB3aWR0aCBkZXRlY3RvclxyXG5leHBvcnQgeyBpbml0TW9kYWxXaWR0aERldGVjdG9yIH0gZnJvbSBcIi4vbGliL3V0aWxzL21vZGFsLXdpZHRoLWRldGVjdG9yXCI7XHJcbmV4cG9ydCB7IGluaXRTZWxlY3RXaWR0aERldGVjdG9yIH0gZnJvbSBcIi4vbGliL3V0aWxzL3NlbGVjdC13aWR0aC1kZXRlY3RvclwiO1xyXG4iXX0=
@@ -2879,6 +2879,182 @@ function initModalWidthDetector() {
2879
2879
  });
2880
2880
  }
2881
2881
 
2882
+ /**
2883
+ * 自动检测 nz-select 最近的父元素宽度,并设置给 nz-select
2884
+ * 当父元素宽度变化时,自动更新 nz-select 的宽度
2885
+ */
2886
+ function initSelectWidthDetector() {
2887
+ if (typeof window === 'undefined' || typeof document === 'undefined') {
2888
+ return;
2889
+ }
2890
+ // 获取最近的父元素(排除自身)
2891
+ function getClosestParent(element) {
2892
+ let parent = element.parentElement;
2893
+ while (parent && parent !== document.body) {
2894
+ // 如果父元素有明确的宽度(非 auto),则返回该父元素
2895
+ const computedStyle = window.getComputedStyle(parent);
2896
+ const width = computedStyle.width;
2897
+ if (width && width !== 'auto' && width !== '0px') {
2898
+ return parent;
2899
+ }
2900
+ parent = parent.parentElement;
2901
+ }
2902
+ // 如果没找到有明确宽度的父元素,返回直接父元素
2903
+ return element.parentElement;
2904
+ }
2905
+ // 找到实际的 select 元素(nz-select 组件渲染后的 DOM 元素)
2906
+ function findActualSelectElement(element) {
2907
+ var _a;
2908
+ // 如果已经是 ant-select 元素,直接返回
2909
+ if ((_a = element.classList) === null || _a === void 0 ? void 0 : _a.contains('ant-select')) {
2910
+ return element;
2911
+ }
2912
+ // 如果是 nz-select 组件标签,查找其渲染后的 ant-select 元素
2913
+ if (element.tagName === 'NZ-SELECT') {
2914
+ const actualSelect = element.querySelector('.ant-select');
2915
+ return actualSelect || element;
2916
+ }
2917
+ // 在子元素中查找 ant-select
2918
+ const actualSelect = element.querySelector('.ant-select');
2919
+ return actualSelect || element;
2920
+ }
2921
+ // 获取原始的 nz-select 组件元素(用于读取 custom-width 属性)
2922
+ function getOriginalSelectElement(element) {
2923
+ // 如果已经是 nz-select 组件标签,直接返回
2924
+ if (element.tagName === 'NZ-SELECT') {
2925
+ return element;
2926
+ }
2927
+ // 向上查找 nz-select 组件标签
2928
+ let parent = element.parentElement;
2929
+ while (parent && parent !== document.body) {
2930
+ if (parent.tagName === 'NZ-SELECT') {
2931
+ return parent;
2932
+ }
2933
+ parent = parent.parentElement;
2934
+ }
2935
+ return null;
2936
+ }
2937
+ // 检查并设置 nz-select 的宽度
2938
+ function setSelectWidth(selectElement) {
2939
+ const actualSelect = findActualSelectElement(selectElement);
2940
+ if (!actualSelect) {
2941
+ return;
2942
+ }
2943
+ // 检查是否有自定义宽度属性
2944
+ const originalSelect = getOriginalSelectElement(selectElement);
2945
+ if (originalSelect) {
2946
+ const customWidth = originalSelect.getAttribute('custom-width');
2947
+ if (customWidth) {
2948
+ // 使用自定义宽度
2949
+ actualSelect.style.width = customWidth;
2950
+ return;
2951
+ }
2952
+ }
2953
+ // 如果没有自定义宽度,使用计算出的父元素宽度
2954
+ const parent = getClosestParent(actualSelect);
2955
+ if (parent) {
2956
+ const parentWidth = parent.offsetWidth;
2957
+ if (parentWidth > 0) {
2958
+ // 设置宽度,可以减去一些 padding/margin 来避免溢出
2959
+ // 这里直接使用父元素宽度,如果需要可以调整
2960
+ actualSelect.style.width = `${parentWidth}px`;
2961
+ }
2962
+ }
2963
+ }
2964
+ // 使用 MutationObserver 监听 DOM 变化
2965
+ const observer = new MutationObserver((mutations) => {
2966
+ mutations.forEach((mutation) => {
2967
+ mutation.addedNodes.forEach((node) => {
2968
+ var _a, _b, _c;
2969
+ if (node.nodeType === Node.ELEMENT_NODE) {
2970
+ const element = node;
2971
+ // 检查是否是 nz-select 组件标签
2972
+ if (element.tagName === 'NZ-SELECT') {
2973
+ // 等待 Angular 组件渲染完成
2974
+ setTimeout(() => {
2975
+ setSelectWidth(element);
2976
+ observeResize(element);
2977
+ }, 100);
2978
+ }
2979
+ // 检查是否是 ant-select 元素(nz-select 渲染后的实际元素)
2980
+ if ((_a = element.classList) === null || _a === void 0 ? void 0 : _a.contains('ant-select')) {
2981
+ setTimeout(() => {
2982
+ setSelectWidth(element);
2983
+ observeResize(element);
2984
+ }, 0);
2985
+ }
2986
+ // 检查子元素中是否有 nz-select 或 ant-select
2987
+ const nzSelects = (_b = element.querySelectorAll) === null || _b === void 0 ? void 0 : _b.call(element, 'nz-select');
2988
+ nzSelects === null || nzSelects === void 0 ? void 0 : nzSelects.forEach((select) => {
2989
+ setTimeout(() => {
2990
+ setSelectWidth(select);
2991
+ observeResize(select);
2992
+ }, 100);
2993
+ });
2994
+ const antSelects = (_c = element.querySelectorAll) === null || _c === void 0 ? void 0 : _c.call(element, '.ant-select');
2995
+ antSelects === null || antSelects === void 0 ? void 0 : antSelects.forEach((select) => {
2996
+ setTimeout(() => {
2997
+ setSelectWidth(select);
2998
+ observeResize(select);
2999
+ }, 0);
3000
+ });
3001
+ }
3002
+ });
3003
+ });
3004
+ });
3005
+ // 使用 ResizeObserver 监听父元素尺寸变化
3006
+ const resizeObserverMap = new WeakMap();
3007
+ function observeResize(selectElement) {
3008
+ if (resizeObserverMap.has(selectElement)) {
3009
+ return;
3010
+ }
3011
+ if (typeof window.ResizeObserver !== 'undefined') {
3012
+ const actualSelect = findActualSelectElement(selectElement);
3013
+ if (!actualSelect) {
3014
+ return;
3015
+ }
3016
+ const parent = getClosestParent(actualSelect);
3017
+ if (!parent) {
3018
+ return;
3019
+ }
3020
+ const resizeObserver = new window.ResizeObserver(() => {
3021
+ setSelectWidth(selectElement);
3022
+ });
3023
+ resizeObserver.observe(parent);
3024
+ resizeObserverMap.set(selectElement, resizeObserver);
3025
+ }
3026
+ }
3027
+ // 开始监听 DOM 变化
3028
+ observer.observe(document.body, {
3029
+ childList: true,
3030
+ subtree: true,
3031
+ });
3032
+ // 检查已存在的 nz-select 和 ant-select
3033
+ const checkExistingSelects = () => {
3034
+ // 检查 nz-select 组件标签
3035
+ document.querySelectorAll('nz-select').forEach((element) => {
3036
+ setTimeout(() => {
3037
+ setSelectWidth(element);
3038
+ observeResize(element);
3039
+ }, 100);
3040
+ });
3041
+ // 检查 ant-select 元素
3042
+ document.querySelectorAll('.ant-select').forEach((element) => {
3043
+ setTimeout(() => {
3044
+ setSelectWidth(element);
3045
+ observeResize(element);
3046
+ }, 0);
3047
+ });
3048
+ };
3049
+ // 延迟执行,确保 DOM 已完全加载
3050
+ if (document.readyState === 'loading') {
3051
+ document.addEventListener('DOMContentLoaded', checkExistingSelects);
3052
+ }
3053
+ else {
3054
+ checkExistingSelects();
3055
+ }
3056
+ }
3057
+
2882
3058
  /*
2883
3059
  * Public API Surface of pro-table
2884
3060
  */
@@ -2887,5 +3063,5 @@ function initModalWidthDetector() {
2887
3063
  * Generated bundle index. Do not edit.
2888
3064
  */
2889
3065
 
2890
- export { AntdFormService, ArrayFormService, DefaultPlatePrefixLoadService, PLATE_PREFIX_LOAD_SERVICE, PRO_TABLE_COLUMN_REMOTE, PRO_TABLE_DEFAULT_COLUMN, PRO_TABLE_DEFAULT_PROPS, PageContainerModule, PlateInputModule, ProTableComponent, ProTableModule, TableSearchBarModule, TrimInputModule, initModalWidthDetector, ɵ0, ɵ1, ɵ2, PageContainerComponent as ɵa, TableSearchBarComponent as ɵb, TrimInputDirective as ɵc, PlateInputComponent as ɵd, ColmunsSettingComponent as ɵe, DynamicSearchFieldComponent as ɵf };
3066
+ export { AntdFormService, ArrayFormService, DefaultPlatePrefixLoadService, PLATE_PREFIX_LOAD_SERVICE, PRO_TABLE_COLUMN_REMOTE, PRO_TABLE_DEFAULT_COLUMN, PRO_TABLE_DEFAULT_PROPS, PageContainerModule, PlateInputModule, ProTableComponent, ProTableModule, TableSearchBarModule, TrimInputModule, initModalWidthDetector, initSelectWidthDetector, ɵ0, ɵ1, ɵ2, PageContainerComponent as ɵa, TableSearchBarComponent as ɵb, TrimInputDirective as ɵc, PlateInputComponent as ɵd, ColmunsSettingComponent as ɵe, DynamicSearchFieldComponent as ɵf };
2891
3067
  //# sourceMappingURL=yibozhang-pro-table.js.map