From 1380f4e931b639e0f2868f8808effd547b3370cc Mon Sep 17 00:00:00 2001 From: Kagol Date: Fri, 2 Feb 2024 14:29:41 +0800 Subject: [PATCH] merge release-3.13.0 to dev (#1365) * fix(pager): [pager] change pager content to unicode (#1251) * fix(build): fix build error and update versions * fix(build): update theme version * fix(vue): [grid] fix show icon condition (#1259) * docs(grid): [grid] fix grid docs (#1260) * docs(grid): [grid] fix grid docs * docs(grid): [grid] fix grid docs * fix(vue-common): fix process env error (#1277) * fix(vue-common): fix process env error * fix(vue-common): fix process env error * fix(vue-common): fix process env error * fix(modal): fix modal process env error * fix(select): [dialog-box, select] fix select async emit form validate (#1292) * fix(theme): x-design style css var fix (#1286) * fix(renderless): fix popper fixed offset in transform parent (#1332) * fix(vue): [cascader] fix search mode in wujie (#1319) * fix(theme): [grid] fix xDesign grid toolbar button style (#1357) * fix(tree-menu): [tree-menu] Fix the issue of asynchronous loading of tree-menu component (#1362) --------- Co-authored-by: gimmyhehe <975402925@qq.com> Co-authored-by: zzcr <894103554@qq.com> Co-authored-by: wuyiping0628 <42107997+wuyiping0628@users.noreply.github.com> --- .../pc/app/tree-menu/webdoc/tree-menu.js | 2 +- packages/renderless/src/cascader/index.ts | 12 +++++------ packages/renderless/src/tree-menu/index.ts | 4 ++-- packages/theme/src/grid/smb-theme.js | 6 +++++- packages/theme/src/grid/toolbar.less | 10 +++++----- packages/theme/src/grid/vars.less | 20 ++++++++++++++++++- 6 files changed, 37 insertions(+), 17 deletions(-) diff --git a/examples/sites/demos/pc/app/tree-menu/webdoc/tree-menu.js b/examples/sites/demos/pc/app/tree-menu/webdoc/tree-menu.js index e4311a46d..64f423a3c 100644 --- a/examples/sites/demos/pc/app/tree-menu/webdoc/tree-menu.js +++ b/examples/sites/demos/pc/app/tree-menu/webdoc/tree-menu.js @@ -467,7 +467,7 @@ export default { 'zh-CN': '自定义获取服务端数据源的方法,返回一个 Promise 对象', 'en-US': 'Customize the method for obtaining server-side data sources and return a Promise object' }, - 'demoId': 'get-menu-data-sync' + 'demoId': 'data-resource' }, { 'name': 'indent', diff --git a/packages/renderless/src/cascader/index.ts b/packages/renderless/src/cascader/index.ts index bb8565834..2612cbbcb 100644 --- a/packages/renderless/src/cascader/index.ts +++ b/packages/renderless/src/cascader/index.ts @@ -421,9 +421,7 @@ export const calcCollapseTags = const tags: HTMLDivElement[] = Array.from(content.querySelectorAll('.tiny-tag')) let { total, dom, idx } = { total: collapseTagWidth as number, dom: null as HTMLDivElement | null, idx: 0 } - - // eslint-disable-next-line array-callback-return - tags.some((tag, index) => { + tags.forEach((tag, index) => { if (tag !== tagsLength) { const { width: tagContentWidth, marginRight, marginLeft } = tag && window.getComputedStyle(tag) total += parseFloat(tagContentWidth) + parseFloat(marginRight) + parseFloat(marginLeft) @@ -618,10 +616,10 @@ export const updateStyle = const tags = $el.querySelector(CASCADER.TagClass) let suggestionPanelEl: HTMLDivElement | null = null - // eslint-disable-next-line no-cond-assign - if (suggestionPanel && (suggestionPanelEl = suggestionPanel.$el)) { - const suggestionList: HTMLDivElement | null = suggestionPanelEl?.querySelector(CASCADER.ListClass) - suggestionList && (suggestionList.style.minWidth = inputInner.offsetWidth + 'px') + if (suggestionPanel) { + suggestionPanelEl = suggestionPanel.$el + const suggestionList: HTMLDivElement | null = suggestionPanelEl.querySelector(CASCADER.ListClass) + suggestionList.style.minWidth = inputInner.offsetWidth + 'px' } if (tags) { diff --git a/packages/renderless/src/tree-menu/index.ts b/packages/renderless/src/tree-menu/index.ts index 7269476d8..fb2da51b7 100644 --- a/packages/renderless/src/tree-menu/index.ts +++ b/packages/renderless/src/tree-menu/index.ts @@ -13,14 +13,14 @@ import type { ITreeMenuApi, ITreeMenuState, ITreeMenuProps, ITreeMenuData, ITree export const initData = ({ state, props, service, api }: { state: ITreeMenuState; props: ITreeMenuProps; service: any; api: ITreeMenuApi }) => - () => { + async () => { if (props.data) { state.data = props.data return } if (typeof service.getMenuDataSync === 'function') { - const menuData = service.getMenuDataSync() + const menuData = await service.getMenuDataSync() state.data = api.setMenuKey({ newData: [], menuData }) } diff --git a/packages/theme/src/grid/smb-theme.js b/packages/theme/src/grid/smb-theme.js index 00f0ac2e6..13e175489 100644 --- a/packages/theme/src/grid/smb-theme.js +++ b/packages/theme/src/grid/smb-theme.js @@ -19,5 +19,9 @@ export const tinyGridSmbTheme = { 'ti-grid-icon-color': 'var(--ti-common-color-icon)', 'ti-grid-checkbox-icon-size': 'var(--ti-common-font-size-2)', 'ti-grid-checkbox-bg-color-checked': '#1476FF', - 'ti-grid-radio-bg-color-checked': '#1476FF' + 'ti-grid-radio-bg-color-checked': '#1476FF', + 'ti-grid-toolbar-btn-height': 'var(--ti-common-size-8x, 32px)', + 'ti-grid-toolbar-btn-width': 'var(--ti-common-size-8x, 32px)', + 'ti-grid-toolbar-btn-border-color': 'var(--ti-common-color-line-normal, #c2c2c2)', + 'ti-grid-toolbar-btn-border-radius': 'calc(var(--ti-common-size-base, 4px) + 2px)' } diff --git a/packages/theme/src/grid/toolbar.less b/packages/theme/src/grid/toolbar.less index 56a08b965..c2101237a 100644 --- a/packages/theme/src/grid/toolbar.less +++ b/packages/theme/src/grid/toolbar.less @@ -84,11 +84,11 @@ .@{grid-refresh-prefix-cls}__wrapper, .@{grid-custom-prefix-cls}__wrapper { float: right; - width: 30px; - height: 30px; - line-height: 30px; - border: solid 1px var(--ti-grid-border-color); - border-radius: 3px; + width: var(--ti-grid-toolbar-btn-width); + height: var(--ti-grid-toolbar-btn-height); + line-height: var(--ti-grid-toolbar-btn-height); + border: solid 1px var(--ti-grid-toolbar-btn-border-color); + border-radius: var(--ti-grid-toolbar-btn-border-radius); text-align: center; margin: 0 4px; display: flex; diff --git a/packages/theme/src/grid/vars.less b/packages/theme/src/grid/vars.less index 9b9e7b58e..ef11423ad 100644 --- a/packages/theme/src/grid/vars.less +++ b/packages/theme/src/grid/vars.less @@ -12,7 +12,16 @@ .component-css-vars-grid() { // 表格默认字体 - --ti-grid-font-family: var(--ti-common-font-family, 'Helvetica', 'Arial', 'PingFangSC-Regular', 'Hiragino Sans GB', 'Microsoft YaHei', '微软雅黑', 'Microsoft JhengHei'); + --ti-grid-font-family: var( + --ti-common-font-family, + 'Helvetica', + 'Arial', + 'PingFangSC-Regular', + 'Hiragino Sans GB', + 'Microsoft YaHei', + '微软雅黑', + 'Microsoft JhengHei' + ); // 默认表头文本色 --ti-grid-header-text-color: var(--ti-common-color-info-normal, #252b3a); // 默认表体文本色 @@ -152,4 +161,13 @@ --ti-grid-column-icon-scale-size: 1; // 表格无数据背景图片 --ti-table-nodata-td-bg-img-url: url(''); + + // 工具栏按钮高度 + --ti-grid-toolbar-btn-height: calc(var(--ti-common-size-7x, 28px) + 2px); + // 工具栏按钮宽度 + --ti-grid-toolbar-btn-width: calc(var(--ti-common-size-7x, 28px) + 2px); + // 工具栏按钮边框色 + --ti-grid-toolbar-btn-border-color: var(--ti-common-color-line-dividing, #dfe1e6); + // 工具栏按钮边框圆角 + --ti-grid-toolbar-btn-border-radius: calc(var(--ti-common-size-base, 4px) - 1px); }