diff --git a/.eslintrc.js b/.eslintrc.js index b885a86dd..a491cd868 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -7,10 +7,13 @@ module.exports = { 'eslint-comments/disable-enable-pair': 0, 'react/require-default-props': 0, 'react/no-unused-prop-types': 1, + 'react-hooks/exhaustive-deps': 0, 'jsx-a11y/label-has-for': 0, 'jsx-a11y/label-has-associated-control': 0, 'no-loop-func': 0, '@typescript-eslint/no-loop-func': 0, + '@typescript-eslint/consistent-type-imports': 0, + '@typescript-eslint/consistent-type-definitions': 0, 'max-classes-per-file': 0, }, }; diff --git a/.fatherrc.js b/.fatherrc.js index 912aa0aae..96268ae1e 100644 --- a/.fatherrc.js +++ b/.fatherrc.js @@ -1,9 +1,5 @@ -export default { - cjs: 'babel', - esm: { type: 'babel', importLibToEs: true }, - preCommit: { - eslint: true, - prettier: true, - }, - runtimeHelpers: true, -}; +import { defineConfig } from 'father'; + +export default defineConfig({ + plugins: ['@rc-component/father-plugin'], +}); diff --git a/.github/dependabot.yml b/.github/dependabot.yml new file mode 100644 index 000000000..437d0bd3b --- /dev/null +++ b/.github/dependabot.yml @@ -0,0 +1,29 @@ +version: 2 +updates: +- package-ecosystem: npm + directory: "/" + schedule: + interval: daily + time: "21:00" + open-pull-requests-limit: 10 + ignore: + - dependency-name: "@types/react" + versions: + - 17.0.0 + - 17.0.1 + - 17.0.2 + - 17.0.3 + - dependency-name: "@types/react-dom" + versions: + - 17.0.0 + - 17.0.1 + - 17.0.2 + - dependency-name: '@rc-component/np' + versions: + - 1.0.0 + - dependency-name: '@rc-component/tooltip' + versions: + - 1.0.0 + - dependency-name: less + versions: + - 4.1.0 \ No newline at end of file diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml new file mode 100644 index 000000000..f860ff107 --- /dev/null +++ b/.github/workflows/main.yml @@ -0,0 +1,6 @@ +name: ✅ test +on: [push, pull_request] +jobs: + test: + uses: react-component/rc-test/.github/workflows/test.yml@main + secrets: inherit diff --git a/.gitignore b/.gitignore index 0e6334955..8aae36ae1 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,5 @@ .storybook +.vscode *.iml *.log .doc/ @@ -31,4 +32,11 @@ lib /coverage yarn.lock es/ -!tests/__mocks__/rc-util/lib \ No newline at end of file +!tests/__mocks__/rc-util/lib +# umi +.umi +.umi-production +.umi-test +.env.local + +.dumi/ \ No newline at end of file diff --git a/.husky/pre-commit b/.husky/pre-commit new file mode 100644 index 000000000..af5adff9d --- /dev/null +++ b/.husky/pre-commit @@ -0,0 +1 @@ +lint-staged \ No newline at end of file diff --git a/.npmrc b/.npmrc new file mode 100644 index 000000000..c2e0187bd --- /dev/null +++ b/.npmrc @@ -0,0 +1 @@ +node-options="--openssl-legacy-provider" \ No newline at end of file diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 000000000..214377229 --- /dev/null +++ b/.prettierignore @@ -0,0 +1,11 @@ +.doc +.storybook +es +lib +**/*.svg +**/*.ejs +**/*.html +package.json +.umi +.umi-production +.umi-test diff --git a/.prettierrc b/.prettierrc index f307fb192..b04278194 100644 --- a/.prettierrc +++ b/.prettierrc @@ -4,5 +4,7 @@ "singleQuote": true, "tabWidth": 2, "trailingComma": "all", - "printWidth": 100 + "proseWrap": "never", + "printWidth": 100, + "arrowParens": "avoid" } diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index a04c90edb..000000000 --- a/.travis.yml +++ /dev/null @@ -1,30 +0,0 @@ -language: node_js - -sudo: false - -notifications: - email: - - hualei5280@gmail.com - -node_js: -- 14 - -before_install: -- | - if ! git diff --name-only $TRAVIS_COMMIT_RANGE | grep -qvE '(\.md$)|(^(docs|examples))/' - then - echo "Only docs were updated, stopping build process." - exit - fi -script: -- | - if [ "$TEST_TYPE" = test ]; then - npm test -- --coverage && \ - bash <(curl -s https://codecov.io/bash) - else - npm run $TEST_TYPE - fi -env: - matrix: - - TEST_TYPE=lint - - TEST_TYPE=test \ No newline at end of file diff --git a/.umirc.ts b/.umirc.ts new file mode 100644 index 000000000..f734dd5c1 --- /dev/null +++ b/.umirc.ts @@ -0,0 +1,8 @@ +// more config: https://d.umijs.org/config +import { defineConfig } from 'dumi'; + +export default defineConfig({ + themeConfig: { + name: 'Tree', + }, +}); diff --git a/HISTORY.md b/CHANGELOG.md similarity index 96% rename from HISTORY.md rename to CHANGELOG.md index 4004aede2..1b34e8905 100644 --- a/HISTORY.md +++ b/CHANGELOG.md @@ -1,5 +1,6 @@ -# History ---- +# Changelog + +- https://github.com/react-component/tree/releases ## 3.2.0 `2020-05-08` diff --git a/README.md b/README.md index 5da49ae2b..d56dd7509 100644 --- a/README.md +++ b/README.md @@ -1,23 +1,20 @@ # rc-tree ---- - Tree component. [![NPM version][npm-image]][npm-url] -[![build status][travis-image]][travis-url] -[![Test coverage][coveralls-image]][coveralls-url] -[![Dependencies][david-image]][david-url] -[![DevDependencies][david-dev-image]][david-dev-url] [![npm download][download-image]][download-url] +[![build status][github-actions-image]][github-actions-url] +[![Codecov][codecov-image]][codecov-url] [![bundle size][bundlephobia-image]][bundlephobia-url] +[![dumi][dumi-image]][dumi-url] [npm-image]: http://img.shields.io/npm/v/rc-tree.svg?style=flat-square [npm-url]: http://npmjs.org/package/rc-tree -[travis-image]: https://img.shields.io/travis/react-component/tree.svg?style=flat-square -[travis-url]: https://travis-ci.org/react-component/tree -[coveralls-image]: https://img.shields.io/coveralls/react-component/tree.svg?style=flat-square -[coveralls-url]: https://coveralls.io/r/react-component/tree?branch=master +[github-actions-image]: https://github.com/react-component/tree/actions/workflows/main.yml/badge.svg +[github-actions-url]: https://github.com/react-component/tree/actions/workflows/main.yml +[codecov-image]: https://img.shields.io/codecov/c/github/react-component/tree/master.svg?style=flat-square +[codecov-url]: https://codecov.io/gh/react-component/tree/ [david-url]: https://david-dm.org/react-component/tree [david-image]: https://david-dm.org/react-component/tree/status.svg?style=flat-square [david-dev-url]: https://david-dm.org/react-component/tree?type=dev @@ -26,6 +23,8 @@ Tree component. [download-url]: https://npmjs.org/package/rc-tree [bundlephobia-url]: https://bundlephobia.com/result?p=rc-tree [bundlephobia-image]: https://badgen.net/bundlephobia/minzip/rc-tree +[dumi-url]: https://github.com/umijs/dumi +[dumi-image]: https://img.shields.io/badge/docs%20by-dumi-blue?style=flat-square ## Screenshots @@ -39,13 +38,14 @@ Tree component. http://localhost:9001/ -online example: http://react-component.github.io/tree/ +online example: https://tree.react-component.now.sh/ -## install +## Install [![rc-tree](https://nodei.co/npm/rc-tree.png)](https://npmjs.org/package/rc-tree) ## Usage +> Note: `import "rc-tree/assets/index.css"` see examples @@ -61,16 +61,16 @@ see examples | checkStrictly | check node precisely, parent and children nodes are not associated | bool | false | | className | additional css class of root dom node | String | '' | | defaultCheckedKeys | default checked treeNodes | String[] | [] | -| defaultExpandedKeys | expand specific treeNodes | String[] | - | +| defaultExpandedKeys | expand specific treeNodes | String[] | [] | | defaultExpandAll | expand all treeNodes | bool | false | | defaultExpandParent | auto expand parent treeNodes when init | bool | true | | defaultSelectedKeys | default selected treeNodes | String[] | [] | | disabled | whether disabled the tree | bool | false | -| draggable | whether can drag treeNode. (drag events are not supported in Internet Explorer 8 and earlier versions or Safari 5.1 and earlier versions.) | bool | false | +| draggable | whether can drag treeNode. (drag events are not supported in Internet Explorer 8 and earlier versions or Safari 5.1 and earlier versions.) | bool \| ({ node }) => boolean | false | | expandedKeys | Controlled expand specific treeNodes | String[] | - | | filterTreeNode | filter some treeNodes as you need. it should return true | function(node) | - | | icon | customize icon. When you pass component, whose render will receive full TreeNode props as component props | element/Function(props) | - | -| loadedKeys | Mark node is loaded when `loadData` is true | string[] | - | +| loadedKeys | Mark node is loaded when `loadData` is true | String[] | - | | loadData | load data asynchronously and the return value should be a promise | function(node) | - | | multiple | whether multiple select | bool | false | | prefixCls | prefix class | String | 'rc-tree' | @@ -94,6 +94,10 @@ see examples | onSelect | click the treeNode to fire | function(selectedKeys, e:{selected: bool, selectedNodes, node, event, nativeEvent}) | - | | switcherIcon | specific the switcher icon. | ReactNode / (props: TreeNodeAttribute) => ReactNode | - | | virtual | Disable virtual scroll when `false` | boolean | - | +| allowDrop | Whether to allow drop on node | ({ dragNode, dropNode, dropPosition }) => boolean | - | +| dropIndicatorRender | The indicator to render when dragging | ({ dropPosition, dropLevelOffset, indent: number, prefixCls }) => ReactNode| - | +| direction | Display direction of the tree, it may affect dragging behavior | `ltr` \| `rtl` | - | +| expandAction | Tree open logic, optional: false \| `click` \| `doubleClick` | string \| boolean | `click` | ### TreeNode props @@ -104,7 +108,7 @@ see examples | name | description | type | default | | --- | --- | --- | --- | | className | additional class to treeNode | String | '' | -| checkable | control node checkable if Tree is checkable | bool | - | +| checkable | control node checkable if Tree is checkable | bool | false | | style | set style to treeNode | Object | '' | | disabled | whether disabled the treeNode | bool | false | | disableCheckbox | whether disable the treeNode' checkbox | bool | false | @@ -114,7 +118,7 @@ see examples | icon | customize icon. When you pass component, whose render will receive full TreeNode props as component props | element/Function(props) | - | | switcherIcon | specific the switcher icon. | ReactNode / (props: TreeNodeAttribute) => ReactNode | - | -## note +## Note The number of treeNodes can be very large, but when enable `checkable`, it will spend more computing time, so we cached some calculations(e.g. `this.treeNodesStates`), to avoid double computing. But, this bring some restrictions, **when you async load treeNodes, you should render tree like this** `{this.state.treeData.length ? {this.state.treeData.map(t => )} : 'loading tree'}` @@ -137,9 +141,9 @@ http://localhost:8018/node_modules/rc-server/node_modules/node-jscover/lib/front rc-tree is released under the MIT license. -## other tree view +## Other tree views -- [ztree](http://www.ztree.me/) -- [jqTree](http://mbraak.github.io/jqTree/) -- [jquery.treeselect](http://travistidwell.com/jquery.treeselect.js/) -- [angular Select Tree](http://a5hik.github.io/angular-multi-select-tree/) +- [zTree](http://www.treejs.cn/) +- [jqTree](https://mbraak.github.io/jqTree/) +- [jquery.treeselect](https://travistidwell.com/jquery.treeselect.js/) +- [Angular Multi Select Tree](https://a5hik.github.io/angular-multi-select-tree/) diff --git a/assets/index.less b/assets/index.less index 808901d1d..b449d4b95 100644 --- a/assets/index.less +++ b/assets/index.less @@ -13,7 +13,7 @@ .@{treeNodePrefixCls} { margin: 0; padding: 0; - line-height: 20px; + line-height: 24px; white-space: nowrap; list-style: none; outline: 0; @@ -24,25 +24,32 @@ -webkit-user-select: none; user-select: none; /* Required to make elements draggable in old WebKit */ - -khtml-user-drag: element; - -webkit-user-drag: element; + // -khtml-user-drag: element; + // -webkit-user-drag: element; } - &.drag-over { - > .draggable { - color: white; - background-color: #316ac5; - border: 1px #316ac5 solid; - opacity: 0.8; - } + + &.dragging { + background: rgba(100, 100, 255, 0.1); } - &.drag-over-gap-top { - > .draggable { - border-top: 2px blue solid; + + &.drop-container { + > .draggable::after { + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + box-shadow: inset 0 0 0 2px red; + content: ''; + } + & ~ .@{treeNodePrefixCls} { + border-left: 2px solid chocolate; } } - &.drag-over-gap-bottom { - > .draggable { - border-bottom: 2px blue solid; + &.drop-target { + background-color: yellowgreen; + & ~ .@{treeNodePrefixCls} { + border-left: none; } } &.filter-node { @@ -56,10 +63,11 @@ padding: 0 0 0 18px; } .@{treePrefixCls}-node-content-wrapper { + position: relative; display: inline-block; - height: 17px; + height: 24px; margin: 0; - padding: 1px 3px 0 0; + padding: 0; text-decoration: none; vertical-align: top; cursor: pointer; @@ -73,7 +81,7 @@ height: 16px; margin-right: 2px; line-height: 16px; - vertical-align: middle; + vertical-align: -0.125em; background-color: transparent; background-image: url(''); background-repeat: no-repeat; @@ -187,7 +195,7 @@ } &-node-selected { background-color: #ffe6b0; - border: 1px #ffb951 solid; + box-shadow: 0 0 0 1px #ffb951; opacity: 0.8; } &-icon__open { @@ -209,9 +217,22 @@ margin-right: 2px; vertical-align: top; } + &-title { + display: inline-block; + } + &-indent { + display: inline-block; + height: 0; + vertical-align: bottom; + } &-indent-unit { - width: 16px; display: inline-block; - padding-left: 18px; + width: 16px; + } + + &-draggable-icon { + display: inline-flex; + justify-content: center; + width: 16px; } } diff --git a/docs/changelog.md b/docs/changelog.md new file mode 100644 index 000000000..beb2eddcc --- /dev/null +++ b/docs/changelog.md @@ -0,0 +1 @@ + diff --git a/docs/demo/animation-draggable.md b/docs/demo/animation-draggable.md new file mode 100644 index 000000000..cd51870e3 --- /dev/null +++ b/docs/demo/animation-draggable.md @@ -0,0 +1,8 @@ +--- +title: Animation Draggable +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/animation.md b/docs/demo/animation.md new file mode 100644 index 000000000..431fe072f --- /dev/null +++ b/docs/demo/animation.md @@ -0,0 +1,8 @@ +--- +title: Animation +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/basic-controlled.md b/docs/demo/basic-controlled.md new file mode 100644 index 000000000..9ef9a3a05 --- /dev/null +++ b/docs/demo/basic-controlled.md @@ -0,0 +1,8 @@ +--- +title: Basic Controlled +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/basic.md b/docs/demo/basic.md new file mode 100644 index 000000000..2bfed0cc5 --- /dev/null +++ b/docs/demo/basic.md @@ -0,0 +1,8 @@ +--- +title: Basic +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/big-data.md b/docs/demo/big-data.md new file mode 100644 index 000000000..695474e64 --- /dev/null +++ b/docs/demo/big-data.md @@ -0,0 +1,8 @@ +--- +title: Big Data +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/contextmenu.md b/docs/demo/contextmenu.md new file mode 100644 index 000000000..b088fcebf --- /dev/null +++ b/docs/demo/contextmenu.md @@ -0,0 +1,8 @@ +--- +title: Context Menu +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/custom-switch-icon.md b/docs/demo/custom-switch-icon.md new file mode 100644 index 000000000..81644e7ea --- /dev/null +++ b/docs/demo/custom-switch-icon.md @@ -0,0 +1,8 @@ +--- +title: Custom Switch Icon +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/draggable-allow-drop.md b/docs/demo/draggable-allow-drop.md new file mode 100644 index 000000000..2cbe21e44 --- /dev/null +++ b/docs/demo/draggable-allow-drop.md @@ -0,0 +1,8 @@ +--- +title: Draggable Allow Drop +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/draggable.md b/docs/demo/draggable.md new file mode 100644 index 000000000..5f167c755 --- /dev/null +++ b/docs/demo/draggable.md @@ -0,0 +1,8 @@ +--- +title: Draggable +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/dropdown.md b/docs/demo/dropdown.md new file mode 100644 index 000000000..1ee32c191 --- /dev/null +++ b/docs/demo/dropdown.md @@ -0,0 +1,8 @@ +--- +title: Dropdown +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/dynamic.md b/docs/demo/dynamic.md new file mode 100644 index 000000000..8470bbfe6 --- /dev/null +++ b/docs/demo/dynamic.md @@ -0,0 +1,8 @@ +--- +title: Dynamic +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/expandAction.md b/docs/demo/expandAction.md new file mode 100644 index 000000000..902c8714a --- /dev/null +++ b/docs/demo/expandAction.md @@ -0,0 +1,8 @@ +--- +title: Expand Action +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/fieldNames.md b/docs/demo/fieldNames.md new file mode 100644 index 000000000..05f5f59c9 --- /dev/null +++ b/docs/demo/fieldNames.md @@ -0,0 +1,8 @@ +--- +title: Field Names +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/funtionTitle.md b/docs/demo/funtionTitle.md new file mode 100644 index 000000000..385d6b7c7 --- /dev/null +++ b/docs/demo/funtionTitle.md @@ -0,0 +1,8 @@ +--- +title: Function Title +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/icon.md b/docs/demo/icon.md new file mode 100644 index 000000000..176aad6a9 --- /dev/null +++ b/docs/demo/icon.md @@ -0,0 +1,8 @@ +--- +title: Icon +nav: + title: Demo + path: /demo +--- + + diff --git a/docs/demo/selectable.md b/docs/demo/selectable.md new file mode 100644 index 000000000..ad30c00e6 --- /dev/null +++ b/docs/demo/selectable.md @@ -0,0 +1,8 @@ +--- +title: Selectable +nav: + title: Demo + path: /demo +--- + + diff --git a/examples/animation-draggable.jsx b/docs/examples/animation-draggable.jsx similarity index 98% rename from examples/animation-draggable.jsx rename to docs/examples/animation-draggable.jsx index ae5dcc75d..cb2985548 100644 --- a/examples/animation-draggable.jsx +++ b/docs/examples/animation-draggable.jsx @@ -2,8 +2,8 @@ react/no-danger, no-param-reassign */ import React from 'react'; import { gData } from './utils/dataUtil'; -import '../assets/index.less'; -import Tree from '../src'; +import '../../assets/index.less'; +import Tree from '@rc-component/tree'; const STYLE = ` .rc-tree-child-tree { diff --git a/examples/animation.jsx b/docs/examples/animation.jsx similarity index 67% rename from examples/animation.jsx rename to docs/examples/animation.jsx index d46cea011..7dcb5c3f1 100644 --- a/examples/animation.jsx +++ b/docs/examples/animation.jsx @@ -1,8 +1,9 @@ /* eslint no-console:0, react/no-danger: 0 */ -import '../assets/index.less'; -import './animation.less'; +import { Provider } from '@rc-component/motion'; +import Tree from '@rc-component/tree'; import React from 'react'; -import Tree from '../src'; +import '../../assets/index.less'; +import './animation.less'; const STYLE = ` .rc-tree-child-tree { @@ -108,43 +109,56 @@ function getTreeData() { const Demo = () => { const treeRef = React.useRef(); + const [enableMotion, setEnableMotion] = React.useState(true); setTimeout(() => { treeRef.current.scrollTo({ key: '0-9-2' }); }, 100); return ( -
-

expanded

-