@gingkoo/pandora-explorer 0.0.1-alpha.74 → 0.0.1-alpha.75

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/lib/es/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @gingkoo/pandora-explorer v0.0.1-alpha.74
2
+ * @gingkoo/pandora-explorer v0.0.1-alpha.75
3
3
  */
4
4
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
5
5
  import cx$1 from 'classnames';
@@ -1270,7 +1270,7 @@ const Draggable = /*#__PURE__*/React__default.forwardRef(({
1270
1270
  });
1271
1271
  });
1272
1272
 
1273
- var css_248z$a = ".frame-explorer-main .header-content {\n padding-top: 12px;\n height: 37px;\n border-bottom: 1px solid #e6e6e6;\n box-sizing: content-box;\n}\n.frame-explorer-main .header-content * {\n box-sizing: content-box;\n}\n.frame-explorer-main .header-content .header-left {\n float: left;\n width: 80px;\n padding-left: 10px;\n overflow: hidden;\n height: 32px;\n}\n.frame-explorer-main .header-content .header-left .btn-group {\n position: relative;\n display: inline-block;\n vertical-align: middle;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn {\n position: relative;\n padding: 3px 6px;\n width: 18px;\n height: 20px;\n line-height: 20px;\n border: 1px solid #ddd;\n font-size: 1em;\n border-radius: 0px;\n background-image: none;\n float: left;\n color: #999;\n white-space: nowrap;\n overflow: hidden;\n text-align: center;\n text-overflow: ellipsis;\n outline: none;\n transition: all 0.16s;\n text-shadow: 0 1px 0 #fff;\n box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 1px rgba(0, 0, 0, 0.075);\n background-color: #fff;\n display: inline-block;\n margin-bottom: 0;\n font-weight: normal;\n vertical-align: middle;\n cursor: pointer;\n display: flex;\n align-items: center;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn > svg {\n font-size: 16px;\n fill: '#323232';\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn + .btn {\n margin-left: -1px;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn:hover {\n background-color: #e4f8ff;\n border-color: #aedaff;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn:hover > svg {\n fill: '#323232';\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn:active {\n background-color: #e4f8ff;\n border-color: #93cfff;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn:active > svg {\n fill: #365f80;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn.disable {\n box-shadow: inset 0 3px 6px rgba(0, 0, 0, 0.1);\n opacity: 0.5;\n border-color: #ddd;\n background: #e6e6e680;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn.disable > svg {\n fill: '#999';\n}\n.frame-explorer-main .header-content .header-middle {\n padding-left: 12px;\n}\n.frame-explorer-main .header-content .header-middle .btn {\n position: relative;\n padding: 3px 6px;\n width: 18px;\n height: 20px;\n line-height: 20px;\n border: 1px solid #ddd;\n font-size: 1em;\n border-radius: 0px;\n background-image: none;\n float: left;\n color: #444;\n margin-left: -1px;\n white-space: nowrap;\n overflow: hidden;\n text-align: center;\n text-overflow: ellipsis;\n outline: none;\n transition: all 0.16s;\n text-shadow: 0 1px 0 #fff;\n background-color: #fff;\n display: inline-block;\n margin-bottom: 0;\n font-weight: normal;\n vertical-align: middle;\n cursor: pointer;\n display: flex;\n align-items: center;\n}\n.frame-explorer-main .header-content .header-middle .btn > svg {\n font-size: 16px;\n}\n.frame-explorer-main .header-content .header-middle .btn + .btn {\n margin-left: -1px;\n}\n.frame-explorer-main .header-content .header-middle .btn:hover {\n background-color: #e4f8ff;\n border-color: #aedaff;\n}\n.frame-explorer-main .header-content .header-middle .btn:active {\n color: #365f80;\n background-color: #e4f8ff;\n border-color: #93cfff;\n}\n.frame-explorer-main .header-content .header-middle .btn.disable {\n cursor: not-allowed;\n opacity: 0.6;\n}\n.frame-explorer-main .header-content .header-middle .header-address {\n width: 50%;\n cursor: text;\n height: 26px;\n overflow: hidden;\n float: left;\n border: 1px solid #ddd;\n margin-left: -1px;\n display: block;\n}\n.frame-explorer-main .header-content .header-middle .header-address-content {\n list-style: none;\n margin: 0;\n margin-top: -1px;\n padding: 0;\n position: relative;\n overflow-y: hidden;\n overflow-x: auto;\n white-space: nowrap;\n height: 50px;\n width: 100%;\n box-sizing: border-box;\n}\n.frame-explorer-main .header-content .header-middle .header-address-item {\n display: inline-block;\n}\n.frame-explorer-main .header-content .header-middle .header-address-item.last {\n margin-right: 50px;\n}\n.frame-explorer-main .header-content .header-middle .header-address-item.first a {\n margin-left: 0px;\n padding-left: 5px;\n font-weight: 800;\n}\n.frame-explorer-main .header-content .header-middle .header-address-item a {\n background-image: url('');\n background-repeat: no-repeat;\n background-position: 100% 0;\n cursor: pointer;\n height: 27px;\n min-width: 16px;\n line-height: 27px;\n max-width: 200px;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n display: inline-block;\n font-size: 1em;\n padding: 0px 25px 0px 25px;\n position: relative;\n margin-left: -15px;\n vertical-align: top;\n color: #666;\n text-decoration: none;\n}\n.frame-explorer-main .header-content .header-middle .header-address-item a:hover {\n background-position: 100% -48px;\n color: #222;\n}\n.frame-explorer-main .header-content .header-middle .header-address .clear {\n clear: both;\n}\n.frame-explorer-main .header-content .header-middle .header-address-input {\n height: 26px;\n width: 50%;\n cursor: text;\n float: left;\n border: 1px solid #ddd;\n margin-left: -1px;\n}\n.frame-explorer-main .header-content .header-middle .header-address-input input {\n border: none;\n height: 25px;\n display: block;\n padding: 0;\n padding-left: 10px;\n padding-right: 10px;\n background: #fff;\n background: none;\n width: 94%;\n font-size: 1em;\n line-height: 25px;\n color: #444;\n appearance: none;\n border-radius: 0;\n outline: none;\n}\n.frame-explorer-main .header-content .header-middle .header-address-input input:focus {\n outline: none;\n}\n.frame-explorer-main .header-content .header-middle .hidden {\n display: none;\n}\n.frame-explorer-main .header-content .header-right .search-box {\n position: absolute;\n right: 20px;\n top: 12px;\n color: #888;\n vertical-align: top;\n}\n.frame-explorer-main .header-content .header-right .search-box * {\n box-sizing: border-box;\n}\n.frame-explorer-main .header-content .header-right .search-box input {\n outline: none;\n height: 26px;\n border: 1px solid #ddd;\n padding: 2px 34px 2px 6px;\n border-radius: 2px;\n vertical-align: top;\n transition: 0.3s;\n color: #444;\n}\n.frame-explorer-main .header-content .header-right .search-box input:hover {\n border-color: #63acff;\n}\n.frame-explorer-main .header-content .header-right .search-box input:focus {\n border-color: #63acff;\n box-shadow: 0 1px 10px #63acff80;\n}\n.frame-explorer-main .header-content .header-right .search-box button {\n position: absolute;\n right: 1px;\n outline: none;\n height: 24px;\n width: 24px;\n top: 1px;\n border: 1px solid transparent;\n border-left: 1px solid #ddd;\n cursor: pointer;\n background: #fff;\n border-radius: 2px;\n padding: 4px;\n}\n.frame-explorer-main .header-content .header-right .search-box button > svg {\n font-size: 14px;\n}\n.frame-explorer-main .header-content .header-right .search-box button:hover > svg {\n color: #63acff;\n}\n.frame-right-main .tools {\n height: 34px;\n min-width: 505px;\n overflow: hidden;\n border-bottom: 1px solid #e6e6e6;\n background: #fefefe;\n box-shadow: 0 5px 10px rgba(0, 0, 0, 0.02);\n z-index: 100;\n box-sizing: content-box;\n}\n.frame-right-main .tools .tools-left {\n display: flex;\n float: left;\n margin: 0 0 0 10px;\n height: 100%;\n align-items: center;\n}\n.frame-right-main .tools .tools-left .btn {\n position: relative;\n background: #fff;\n outline: none;\n border: 1px solid #ccc;\n height: 24px;\n border-radius: 2px;\n padding: 2px 6px;\n cursor: pointer;\n display: flex;\n align-items: center;\n margin-right: 10px;\n}\n.frame-right-main .tools .tools-left .btn > svg {\n font-size: 14px;\n margin-right: 5px;\n vertical-align: top;\n fill: #999;\n}\n.frame-right-main .tools .tools-left .btn > input {\n position: absolute;\n left: 0;\n right: 0;\n bottom: 0;\n top: 0;\n opacity: 0;\n cursor: pointer;\n}\n.frame-right-main .tools .tools-left .btn input[type='file']:hover {\n cursor: pointer;\n font-size: 0;\n}\n.frame-right-main .tools .tools-left .btn:hover {\n border: 1px solid #1677ff;\n color: #1677ff;\n}\n.frame-right-main .tools .tools-left .btn.hidden {\n box-shadow: inset 0 3px 6px rgba(0, 0, 0, 0.1);\n color: #666;\n background-color: #ddd;\n border-color: #ddd;\n}\n.frame-right-main .tools .tools-right {\n margin: 5px 20px 0 0;\n position: absolute;\n right: 0px;\n background: #fff;\n height: 26px;\n box-shadow: -10px 0 10px #fff;\n}\n.frame-right-main .tools .tools-right .btn-group {\n position: relative;\n display: inline-block;\n vertical-align: middle;\n float: right;\n box-sizing: content-box;\n}\n.frame-right-main .tools .tools-right .btn-group > * {\n box-sizing: content-box;\n}\n.frame-right-main .tools .tools-right .btn-group .btn {\n height: 16px;\n position: relative;\n padding: 3px 7px;\n max-width: 150px;\n border: 1px solid #ddd;\n line-height: 1em;\n font-size: 1em;\n border-radius: 0px;\n background-image: none;\n float: left;\n color: #444;\n white-space: nowrap;\n overflow: hidden;\n text-align: center;\n text-overflow: ellipsis;\n outline: none;\n transition: all 0.16s;\n text-shadow: 0 1px 0 #fff;\n box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 1px rgba(0, 0, 0, 0.075);\n background-color: #fff;\n display: inline-block;\n margin-bottom: 0;\n font-weight: normal;\n vertical-align: middle;\n cursor: pointer;\n}\n.frame-right-main .tools .tools-right .btn-group .btn > svg {\n font-size: 14px;\n top: 1px;\n}\n.frame-right-main .tools .tools-right .btn-group .btn + .btn {\n margin-left: -1px;\n}\n.frame-right-main .tools .tools-right .btn-group .btn:hover {\n background-color: #e4f8ff;\n border-color: #aedaff;\n}\n.frame-right-main .tools .tools-right .btn-group .btn:active,\n.frame-right-main .tools .tools-right .btn-group .btn.active {\n color: #365f80;\n background-color: #e4f8ff;\n border-color: #93cfff;\n box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);\n}\n.frame-right-main .tools .tools-right .btn-group .btn.panel-toggle {\n padding: 3px 6px 3px 6px !important;\n margin-left: 10px;\n}\n.frame-right-main .tools .tools-right .btn-group .btn .font-icon {\n padding: 0 2px;\n font-size: 15px;\n display: inline-block;\n background-image: url('');\n background-size: auto !important;\n background-repeat: no-repeat;\n height: 16px;\n width: 12px !important;\n margin-right: 1px !important;\n margin-left: 1px !important;\n color: #999;\n vertical-align: text-bottom;\n font-style: normal;\n text-align: center;\n line-height: 1em;\n box-sizing: content-box;\n}\n.frame-right-main .tools .tools-right .btn-group .btn .font-icon.list-type-icon {\n background-position: 0 -561px;\n}\n.frame-right-main .tools .tools-right .btn-group .btn .font-icon.list-type-list {\n background-position: -16px -624px;\n}\n.frame-right-main .tools .tools-right .btn-group .btn .font-icon.list-type-split {\n background-position: 0 -609px;\n}\n.frame-right-main .tools .tools-right .btn-group .tool {\n display: inline-block;\n width: 24px;\n height: 24px;\n box-sizing: border-box;\n border-radius: 3px;\n margin-bottom: 0;\n padding: 1px 4px;\n font-size: 16px;\n float: left;\n font-weight: normal;\n vertical-align: middle;\n cursor: pointer;\n margin-right: 10px;\n color: #aaa;\n transition: 0.3s;\n}\n.frame-right-main .tools .tools-right .btn-group .tool > svg {\n top: 0;\n}\n.frame-right-main .tools .tools-right .btn-group .tool:hover {\n color: #666;\n background: #eee;\n}\n._slider {\n display: flex;\n width: 45px;\n height: 130px;\n justify-content: center;\n box-shadow: 0 5px 10px rgba(0, 0, 0, 0.1);\n}\n._slider-link {\n position: relative;\n height: calc(100% - 20px);\n width: 6px;\n background: #eee;\n margin: 10px 0;\n border-radius: 6px;\n cursor: pointer;\n}\n._slider-drop {\n width: 16px;\n height: 16px;\n position: absolute;\n border: 2px solid #96dbfa;\n border-radius: 50px;\n left: -5px;\n top: -5px;\n background: #fff;\n cursor: grab;\n transition: box-shadow 0.3s;\n}\n._slider-drop:hover {\n box-shadow: 0 0 0 6px rgba(150, 219, 250, 0.7);\n}\n._slider-drop:active {\n cursor: grabbing;\n background: #96dbfa;\n border-color: #96dbfa;\n box-shadow: none;\n}\n";
1273
+ var css_248z$a = ".frame-explorer-main .header-content {\n padding-top: 12px;\n height: 37px;\n border-bottom: 1px solid #e6e6e6;\n box-sizing: content-box;\n display: flex;\n}\n.frame-explorer-main .header-content * {\n box-sizing: content-box;\n}\n.frame-explorer-main .header-content .header-left {\n width: 80px;\n padding-left: 10px;\n overflow: hidden;\n height: 32px;\n}\n.frame-explorer-main .header-content .header-left .btn-group {\n position: relative;\n display: inline-block;\n vertical-align: middle;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn {\n position: relative;\n padding: 2px 6px;\n width: 18px;\n height: 20px;\n line-height: 20px;\n border: 1px solid #ddd;\n font-size: 1em;\n border-radius: 0px;\n background-image: none;\n float: left;\n color: #999;\n white-space: nowrap;\n overflow: hidden;\n text-align: center;\n text-overflow: ellipsis;\n outline: none;\n transition: all 0.16s;\n text-shadow: 0 1px 0 #fff;\n box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 1px rgba(0, 0, 0, 0.075);\n background-color: #fff;\n display: inline-block;\n margin-bottom: 0;\n font-weight: normal;\n vertical-align: middle;\n cursor: pointer;\n display: flex;\n align-items: center;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn > svg {\n font-size: 16px;\n fill: '#323232';\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn + .btn {\n margin-left: -1px;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn:hover {\n background-color: #e4f8ff;\n border-color: #aedaff;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn:hover > svg {\n fill: '#323232';\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn:active {\n background-color: #e4f8ff;\n border-color: #93cfff;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn:active > svg {\n fill: #365f80;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn.disable {\n box-shadow: inset 0 3px 6px rgba(0, 0, 0, 0.1);\n opacity: 0.5;\n border-color: #ddd;\n background: #e6e6e680;\n}\n.frame-explorer-main .header-content .header-left .btn-group .btn.disable > svg {\n fill: '#999';\n}\n.frame-explorer-main .header-content .header-middle {\n padding-left: 12px;\n display: flex;\n width: calc(50%);\n}\n.frame-explorer-main .header-content .header-middle .btn {\n position: relative;\n padding: 3px 6px;\n width: 18px;\n height: 20px;\n line-height: 20px;\n border: 1px solid #ddd;\n font-size: 1em;\n border-radius: 0px;\n background-image: none;\n float: left;\n color: #444;\n margin-left: -1px;\n white-space: nowrap;\n overflow: hidden;\n text-align: center;\n text-overflow: ellipsis;\n outline: none;\n transition: all 0.16s;\n text-shadow: 0 1px 0 #fff;\n background-color: #fff;\n display: inline-block;\n margin-bottom: 0;\n font-weight: normal;\n vertical-align: middle;\n cursor: pointer;\n display: flex;\n align-items: center;\n}\n.frame-explorer-main .header-content .header-middle .btn > svg {\n font-size: 16px;\n}\n.frame-explorer-main .header-content .header-middle .btn + .btn {\n margin-left: -1px;\n}\n.frame-explorer-main .header-content .header-middle .btn:hover {\n background-color: #e4f8ff;\n border-color: #aedaff;\n}\n.frame-explorer-main .header-content .header-middle .btn:active {\n color: #365f80;\n background-color: #e4f8ff;\n border-color: #93cfff;\n}\n.frame-explorer-main .header-content .header-middle .btn.disable {\n cursor: not-allowed;\n opacity: 0.6;\n}\n.frame-explorer-main .header-content .header-middle .header-address {\n width: 100%;\n cursor: text;\n height: 26px;\n overflow: hidden;\n float: left;\n border: 1px solid #ddd;\n margin-left: -1px;\n display: block;\n}\n.frame-explorer-main .header-content .header-middle .header-address-content {\n list-style: none;\n margin: 0;\n margin-top: -1px;\n padding: 0;\n position: relative;\n overflow-y: hidden;\n overflow-x: auto;\n white-space: nowrap;\n height: 50px;\n width: 100%;\n box-sizing: border-box;\n min-width: 100px;\n}\n.frame-explorer-main .header-content .header-middle .header-address-item {\n display: inline-block;\n}\n.frame-explorer-main .header-content .header-middle .header-address-item.last {\n margin-right: 50px;\n}\n.frame-explorer-main .header-content .header-middle .header-address-item.first a {\n margin-left: 0px;\n padding-left: 5px;\n font-weight: 800;\n}\n.frame-explorer-main .header-content .header-middle .header-address-item a {\n background-image: url('');\n background-repeat: no-repeat;\n background-position: 100% 0;\n cursor: pointer;\n height: 27px;\n min-width: 16px;\n line-height: 27px;\n max-width: 200px;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n display: inline-block;\n font-size: 1em;\n padding: 0px 25px 0px 25px;\n position: relative;\n margin-left: -15px;\n vertical-align: top;\n color: #666;\n text-decoration: none;\n}\n.frame-explorer-main .header-content .header-middle .header-address-item a:hover {\n background-position: 100% -48px;\n color: #222;\n}\n.frame-explorer-main .header-content .header-middle .header-address .clear {\n clear: both;\n}\n.frame-explorer-main .header-content .header-middle .header-address-input {\n height: 26px;\n width: 50%;\n cursor: text;\n border: 1px solid #ddd;\n margin-left: -1px;\n}\n.frame-explorer-main .header-content .header-middle .header-address-input input {\n border: none;\n height: 25px;\n display: block;\n padding: 0;\n padding-left: 10px;\n padding-right: 10px;\n background: #fff;\n background: none;\n width: 94%;\n font-size: 1em;\n line-height: 25px;\n color: #444;\n appearance: none;\n border-radius: 0;\n outline: none;\n}\n.frame-explorer-main .header-content .header-middle .header-address-input input:focus {\n outline: none;\n}\n.frame-explorer-main .header-content .header-middle .hidden {\n display: none;\n}\n.frame-explorer-main .header-content .header-right .search-box {\n position: absolute;\n right: 20px;\n top: 12px;\n color: #888;\n vertical-align: top;\n}\n.frame-explorer-main .header-content .header-right .search-box * {\n box-sizing: border-box;\n}\n.frame-explorer-main .header-content .header-right .search-box input {\n outline: none;\n height: 28px;\n border: 1px solid #ddd;\n padding: 2px 34px 2px 6px;\n border-radius: 2px;\n vertical-align: top;\n transition: 0.3s;\n color: #444;\n}\n.frame-explorer-main .header-content .header-right .search-box input:hover {\n border-color: #63acff;\n}\n.frame-explorer-main .header-content .header-right .search-box input:focus {\n border-color: #63acff;\n box-shadow: 0 1px 10px #63acff80;\n}\n.frame-explorer-main .header-content .header-right .search-box button {\n position: absolute;\n right: 1px;\n outline: none;\n height: 26px;\n width: 26px;\n top: 1px;\n border: 1px solid transparent;\n border-left: 1px solid #ddd;\n cursor: pointer;\n background: #fff;\n border-radius: 2px;\n padding: 5px;\n}\n.frame-explorer-main .header-content .header-right .search-box button > svg {\n font-size: 14px;\n}\n.frame-explorer-main .header-content .header-right .search-box button:hover > svg {\n color: #63acff;\n}\n.frame-right-main .tools {\n height: 34px;\n min-width: 505px;\n overflow: hidden;\n border-bottom: 1px solid #e6e6e6;\n background: #fefefe;\n box-shadow: 0 5px 10px rgba(0, 0, 0, 0.02);\n z-index: 100;\n box-sizing: content-box;\n}\n.frame-right-main .tools .tools-left {\n display: flex;\n float: left;\n margin: 0 0 0 10px;\n height: 100%;\n align-items: center;\n}\n.frame-right-main .tools .tools-left .btn {\n position: relative;\n background: #fff;\n outline: none;\n border: 1px solid #ccc;\n height: 24px;\n border-radius: 2px;\n padding: 2px 6px;\n cursor: pointer;\n display: flex;\n align-items: center;\n margin-right: 10px;\n}\n.frame-right-main .tools .tools-left .btn > svg {\n font-size: 14px;\n margin-right: 5px;\n vertical-align: top;\n fill: #999;\n}\n.frame-right-main .tools .tools-left .btn > input {\n position: absolute;\n left: 0;\n right: 0;\n bottom: 0;\n top: 0;\n opacity: 0;\n cursor: pointer;\n}\n.frame-right-main .tools .tools-left .btn input[type='file']:hover {\n cursor: pointer;\n font-size: 0;\n}\n.frame-right-main .tools .tools-left .btn:hover {\n border: 1px solid #1677ff;\n color: #1677ff;\n}\n.frame-right-main .tools .tools-left .btn.hidden {\n box-shadow: inset 0 3px 6px rgba(0, 0, 0, 0.1);\n color: #666;\n background-color: #ddd;\n border-color: #ddd;\n}\n.frame-right-main .tools .tools-right {\n margin: 5px 20px 0 0;\n position: absolute;\n right: 0px;\n background: #fff;\n height: 26px;\n box-shadow: -10px 0 10px #fff;\n}\n.frame-right-main .tools .tools-right .btn-group {\n position: relative;\n display: inline-block;\n vertical-align: middle;\n float: right;\n box-sizing: content-box;\n}\n.frame-right-main .tools .tools-right .btn-group > * {\n box-sizing: content-box;\n}\n.frame-right-main .tools .tools-right .btn-group .btn {\n height: 16px;\n position: relative;\n padding: 3px 7px;\n max-width: 150px;\n border: 1px solid #ddd;\n line-height: 1em;\n font-size: 1em;\n border-radius: 0px;\n background-image: none;\n float: left;\n color: #444;\n white-space: nowrap;\n overflow: hidden;\n text-align: center;\n text-overflow: ellipsis;\n outline: none;\n transition: all 0.16s;\n text-shadow: 0 1px 0 #fff;\n box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 1px rgba(0, 0, 0, 0.075);\n background-color: #fff;\n display: inline-block;\n margin-bottom: 0;\n font-weight: normal;\n vertical-align: middle;\n cursor: pointer;\n}\n.frame-right-main .tools .tools-right .btn-group .btn > svg {\n font-size: 14px;\n top: 1px;\n}\n.frame-right-main .tools .tools-right .btn-group .btn + .btn {\n margin-left: -1px;\n}\n.frame-right-main .tools .tools-right .btn-group .btn:hover {\n background-color: #e4f8ff;\n border-color: #aedaff;\n}\n.frame-right-main .tools .tools-right .btn-group .btn:active,\n.frame-right-main .tools .tools-right .btn-group .btn.active {\n color: #365f80;\n background-color: #e4f8ff;\n border-color: #93cfff;\n box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);\n}\n.frame-right-main .tools .tools-right .btn-group .btn.panel-toggle {\n padding: 3px 6px 3px 6px !important;\n margin-left: 10px;\n}\n.frame-right-main .tools .tools-right .btn-group .btn .font-icon {\n padding: 0 2px;\n font-size: 15px;\n display: inline-block;\n background-image: url('');\n background-size: auto !important;\n background-repeat: no-repeat;\n height: 16px;\n width: 12px !important;\n margin-right: 1px !important;\n margin-left: 1px !important;\n color: #999;\n vertical-align: text-bottom;\n font-style: normal;\n text-align: center;\n line-height: 1em;\n box-sizing: content-box;\n}\n.frame-right-main .tools .tools-right .btn-group .btn .font-icon.list-type-icon {\n background-position: 0 -561px;\n}\n.frame-right-main .tools .tools-right .btn-group .btn .font-icon.list-type-list {\n background-position: -16px -624px;\n}\n.frame-right-main .tools .tools-right .btn-group .btn .font-icon.list-type-split {\n background-position: 0 -609px;\n}\n.frame-right-main .tools .tools-right .btn-group .tool {\n display: inline-block;\n width: 24px;\n height: 24px;\n box-sizing: border-box;\n border-radius: 3px;\n margin-bottom: 0;\n padding: 1px 4px;\n font-size: 16px;\n float: left;\n font-weight: normal;\n vertical-align: middle;\n cursor: pointer;\n margin-right: 10px;\n color: #aaa;\n transition: 0.3s;\n}\n.frame-right-main .tools .tools-right .btn-group .tool > svg {\n top: 0;\n}\n.frame-right-main .tools .tools-right .btn-group .tool:hover {\n color: #666;\n background: #eee;\n}\n._slider {\n display: flex;\n width: 45px;\n height: 130px;\n justify-content: center;\n box-shadow: 0 5px 10px rgba(0, 0, 0, 0.1);\n}\n._slider-link {\n position: relative;\n height: calc(100% - 20px);\n width: 6px;\n background: #eee;\n margin: 10px 0;\n border-radius: 6px;\n cursor: pointer;\n}\n._slider-drop {\n width: 16px;\n height: 16px;\n position: absolute;\n border: 2px solid #96dbfa;\n border-radius: 50px;\n left: -5px;\n top: -5px;\n background: #fff;\n cursor: grab;\n transition: box-shadow 0.3s;\n}\n._slider-drop:hover {\n box-shadow: 0 0 0 6px rgba(150, 219, 250, 0.7);\n}\n._slider-drop:active {\n cursor: grabbing;\n background: #96dbfa;\n border-color: #96dbfa;\n box-shadow: none;\n}\n";
1274
1274
  styleInject(css_248z$a);
1275
1275
 
1276
1276
  let _$2 = t => t,
@@ -1620,7 +1620,7 @@ function Slider(props) {
1620
1620
  var css_248z$9 = ".explorer-menu {\n height: 100%;\n}\n";
1621
1621
  styleInject(css_248z$9);
1622
1622
 
1623
- var css_248z$8 = ".explorer-tree {\n width: 100%;\n height: 100%;\n}\n.explorer-tree-switch {\n height: 31px;\n width: 24px;\n display: flex;\n justify-content: center;\n align-items: center;\n vertical-align: top !important;\n color: #aaa;\n border-radius: 2px;\n}\n.explorer-tree-switch:hover {\n color: #1890ff;\n background-color: rgba(0, 0, 0, 0.03);\n}\n.explorer-tree-switch.open {\n color: #1890ff;\n}\n.explorer-tree-switch.open > svg {\n transform: rotate(90deg);\n}\n.explorer-tree-switch.loading {\n background: transparent;\n animation: rotate 1s linear infinite;\n}\n.explorer-tree-icon {\n display: inline-block;\n width: 20px;\n height: 20px;\n margin: 6px 0px;\n background-repeat: no-repeat;\n background-position: center;\n background-size: cover;\n border-radius: 5px;\n font-style: normal;\n pointer-events: none;\n vertical-align: top;\n}\n.explorer-tree-node {\n display: flex;\n height: 100%;\n align-items: center;\n}\n.explorer-tree-node .node-title {\n flex: 1;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n}\n.explorer-tree-node .node-menu {\n display: none;\n flex-shrink: 0;\n width: 30px;\n justify-content: center;\n align-items: center;\n}\n.explorer-tree-node .node-menu .node-menu-icon {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 14px;\n height: 14px;\n border: 1px solid #ccc;\n border-radius: 2px;\n cursor: pointer;\n z-index: 50;\n background: #fff;\n color: #ccc;\n font-size: 7px;\n transition: 0.3s;\n}\n.explorer-tree-node .node-menu .node-menu-icon > svg {\n transform: rotate(90deg);\n}\n.explorer-tree-node .node-menu .node-menu-icon:hover {\n border: 1px solid #1890ff;\n color: #1890ff;\n}\n.explorer-tree-node .node-input {\n display: inline-block;\n width: 100%;\n height: 24px;\n outline: 0;\n border: 1px solid #eee;\n border-radius: 3px;\n transition: 0.3s;\n padding: 0 5px;\n}\n.explorer-tree-node .node-input:hover {\n border: 1px solid #1890ff;\n}\n.explorer-tree-node .node-input:focus {\n border: 1px solid #1890ff;\n}\n.explorer-tree-node:hover .node-menu {\n display: flex;\n}\n.explorer-tree-row {\n display: flex;\n width: 100%;\n height: 100%;\n align-items: center;\n}\n.explorer-tree-row .row-item {\n display: flex;\n padding: 0 10px;\n flex: 1 0 0;\n user-select: none;\n}\n.explorer-tree-row .row-item .row-item-content {\n flex: 1 0 0;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n display: flex;\n align-items: center;\n}\n.explorer-tree-row .row-item .row-item-content > input {\n height: 24px;\n outline: none;\n width: 100%;\n outline: 0;\n border: 0;\n}\n.explorer-tree-row .row-item-check {\n display: flex;\n width: 19px;\n align-items: center;\n box-sizing: border-box;\n pointer-events: all;\n}\n.explorer-tree-row .row-item-check .btn-check {\n display: inline-block;\n height: 19px;\n width: 19px;\n flex-shrink: 0;\n z-index: 11;\n font-size: 20px;\n text-align: center;\n border-radius: 50%;\n background: rgba(0, 0, 0, 0.05);\n color: #fff;\n line-height: 0;\n opacity: 0;\n cursor: pointer;\n transition: opacity 0.3s;\n margin: 2px;\n}\n.explorer-tree-row .row-item-check .btn-check > svg {\n position: relative;\n width: 23px;\n height: 23px;\n left: -2px;\n top: -2px;\n}\n.explorer-tree-row .row-item-check.active .btn-check {\n opacity: 1;\n background: #3b8cff;\n}\n.explorer-tree.table .tree-scroll-x {\n width: 100%;\n overflow: hidden;\n overflow-x: auto;\n}\n.explorer-tree.table .tree-scroll-x::-webkit-scrollbar {\n display: none;\n}\n.explorer-tree.table .tree-scroll {\n position: absolute;\n left: 0;\n right: 0;\n top: 0;\n bottom: 0;\n z-index: 10;\n overflow: auto;\n}\n.explorer-tree.table .rc-tree {\n height: calc(100% - 26px);\n}\n.explorer-tree.table .rc-tree-list-holder-inner {\n overflow: auto;\n}\n.explorer-tree.table .rc-tree-list {\n height: 100%;\n}\n.explorer-tree.table .rc-tree-checkbox {\n display: none !important;\n}\n.explorer-tree.table .rc-tree-treenode {\n border-radius: 2px;\n width: fit-content;\n opacity: 0.8;\n z-index: 100;\n pointer-events: all;\n}\n.explorer-tree.table .rc-tree-treenode.rc-tree-treenode-selected {\n background: #4581a60d !important;\n}\n.explorer-tree.table .rc-tree-treenode:nth-child(odd) {\n background: #4664780d;\n}\n.explorer-tree.table .rc-tree-list-holder-inner {\n padding: 8px 0 0 8px;\n}\n.explorer-tree.table .rc-tree-treenode-leaf-last:last-child {\n height: 200px;\n width: 1px;\n}\n.explorer-tree.table .rc-tree-treenode-checkbox-checked {\n background: #cce8ff !important;\n border: 1px solid #99d1ff;\n}\n.explorer-tree .rc-tree-iconEle {\n height: 31px !important;\n vertical-align: top !important;\n width: auto !important;\n}\n.explorer-tree .rc-tree-treenode {\n position: relative;\n height: 31px;\n line-height: 31px;\n border: 1px solid transparent;\n user-select: none;\n display: flex;\n}\n.explorer-tree .rc-tree-treenode > .rc-tree-node-content-wrapper {\n height: 31px !important;\n display: flex !important;\n flex: 1;\n margin-left: calc(24px - 20px);\n overflow: hidden;\n}\n.explorer-tree .rc-tree-treenode > .rc-tree-node-selected {\n background-color: transparent;\n box-shadow: none;\n opacity: 1;\n}\n.explorer-tree .rc-tree-treenode.rc-tree-treenode-selected {\n background-color: #cce8ff !important;\n border: 1px solid #1890ff;\n opacity: 0.8;\n}\n.explorer-tree .rc-tree-treenode.rc-tree-treenode-selected .node-menu {\n display: flex;\n}\n.explorer-tree .rc-tree-treenode:hover {\n background: #e5f3ff !important;\n box-shadow: 0 0 0 1px transparent;\n}\n.explorer-tree .rc-tree-treenode.hover {\n background: #e5f3ff !important;\n}\n.explorer-tree .rc-tree-switcher {\n flex-shrink: 0;\n width: 20px !important;\n height: 31px !important;\n vertical-align: top !important;\n background-image: none !important;\n}\n.explorer-tree .rc-tree-title {\n display: inline-block;\n height: 31px;\n width: 100%;\n}\n.explorer-tree.showLine .rc-tree-indent {\n height: 31px;\n}\n.explorer-tree.showLine .rc-tree-indent > .rc-tree-indent-unit {\n position: relative;\n}\n.explorer-tree.showLine .rc-tree-indent > .rc-tree-indent-unit::after {\n display: inline-block;\n position: absolute;\n content: '';\n width: 1px;\n left: 10px;\n height: 31px;\n background-color: rgba(0, 0, 0, 0.075);\n}\n.explorer-tree.showLine .rc-tree-indent-unit {\n width: 20px;\n height: 31px;\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:last-child {\n position: relative;\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:last-child::before {\n content: '';\n display: inline-block;\n position: absolute;\n width: 8px;\n top: calc(31px / 2);\n left: 10px;\n height: 1px;\n background-color: rgba(0, 0, 0, 0.075);\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:last-child::after {\n display: inline-block;\n position: absolute;\n content: '';\n width: 1px;\n left: 10px;\n top: 0;\n height: calc(31px / 2);\n background-color: rgba(0, 0, 0, 0.075);\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:first-child {\n position: relative;\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:first-child::before {\n display: none;\n content: '';\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:first-child::after {\n display: inline-block;\n position: absolute;\n content: '';\n width: 1px;\n left: 10px;\n height: 31px;\n background-color: rgba(0, 0, 0, 0.075);\n}\n.explorer-tree.explorer-checks .rc-tree-treenode:hover .row-item-check .btn-check {\n opacity: 1;\n}\n.explorer-tree .rc-tree-list-scrollbar-thumb {\n background: #bbb !important;\n}\n.explorer-tree .rc-tree-list-scrollbar {\n width: 5px !important;\n}\n.explorer-tree .node-motion {\n transition: all 0.3s;\n overflow-y: hidden;\n}\n.explorer-tree .rc-tree-child-tree {\n display: block;\n}\n.explorer-table-header {\n display: flex;\n width: fit-content;\n min-width: 100%;\n height: 25px;\n line-height: 25px;\n color: #448;\n border-bottom: 1px solid #e3e3e3;\n box-shadow: 0 6px 10px rgba(0, 0, 0, 0.05);\n background: #fff;\n}\n.explorer-table-header .item {\n padding: 0 10px 0 0;\n flex: 1 0 0;\n margin-left: -10px;\n border-right: 1px solid #eee;\n user-select: none;\n min-width: 80px;\n}\n.explorer-table-header .item:first-child {\n padding-left: 20px;\n}\n.explorer-table-header .resize {\n position: relative;\n flex: 0 0 20px;\n width: 20px;\n z-index: 10;\n cursor: col-resize;\n left: -10px;\n transition: background 0.2s;\n}\n.explorer-table-header .resize::before {\n content: '';\n position: fixed;\n width: 1px;\n height: 2000px;\n z-index: 10;\n margin-left: 10px;\n visibility: hidden;\n opacity: 0;\n transition: all 0.2s;\n}\n.explorer-table-header .resize:hover {\n background: #1890ff30;\n}\n.explorer-table-header .resize.resize-focus {\n z-index: 9999;\n}\n.explorer-table-header .resize.resize-focus:before {\n opacity: 1;\n background: #1890ff;\n visibility: visible;\n}\n.explorer-table-header .resize:last-child {\n flex: 0 0 10px;\n width: 10px;\n}\n.explorer-table-header.item-resize {\n z-index: 10;\n}\n@keyframes rotate {\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(360deg);\n }\n}\n";
1623
+ var css_248z$8 = ".explorer-tree {\n width: 100%;\n height: 100%;\n}\n.explorer-tree-switch {\n height: 31px;\n width: 24px;\n display: flex;\n justify-content: center;\n align-items: center;\n vertical-align: top !important;\n color: #aaa;\n border-radius: 2px;\n}\n.explorer-tree-switch:hover {\n color: #1890ff;\n background-color: rgba(0, 0, 0, 0.03);\n}\n.explorer-tree-switch.open {\n color: #1890ff;\n}\n.explorer-tree-switch.open > svg {\n transform: rotate(90deg);\n}\n.explorer-tree-switch.loading {\n background: transparent;\n animation: rotate 1s linear infinite;\n}\n.explorer-tree-icon {\n display: inline-block;\n width: 20px;\n height: 20px;\n margin: 6px 0px;\n background-repeat: no-repeat;\n background-position: center;\n background-size: cover;\n border-radius: 5px;\n font-style: normal;\n pointer-events: none;\n vertical-align: top;\n}\n.explorer-tree-node {\n display: flex;\n height: 100%;\n align-items: center;\n}\n.explorer-tree-node .node-title {\n flex: 1;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n}\n.explorer-tree-node .node-menu {\n display: none;\n flex-shrink: 0;\n width: 30px;\n justify-content: center;\n align-items: center;\n}\n.explorer-tree-node .node-menu .node-menu-icon {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 14px;\n height: 14px;\n border: 1px solid #ccc;\n border-radius: 2px;\n cursor: pointer;\n z-index: 50;\n background: #fff;\n color: #ccc;\n font-size: 7px;\n transition: 0.3s;\n}\n.explorer-tree-node .node-menu .node-menu-icon > svg {\n transform: rotate(90deg);\n}\n.explorer-tree-node .node-menu .node-menu-icon:hover {\n border: 1px solid #1890ff;\n color: #1890ff;\n}\n.explorer-tree-node .node-input {\n display: inline-block;\n width: 100%;\n height: 24px;\n outline: 0;\n border: 1px solid #eee;\n border-radius: 3px;\n transition: 0.3s;\n padding: 0 5px;\n}\n.explorer-tree-node .node-input:hover {\n border: 1px solid #1890ff;\n}\n.explorer-tree-node .node-input:focus {\n border: 1px solid #1890ff;\n}\n.explorer-tree-node:hover .node-menu {\n display: flex;\n}\n.explorer-tree-row {\n display: flex;\n width: 100%;\n height: 100%;\n align-items: center;\n}\n.explorer-tree-row .row-item {\n display: flex;\n padding: 0 10px;\n flex: 1 0 0;\n user-select: none;\n}\n.explorer-tree-row .row-item .row-item-content {\n flex: 1 0 0;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n display: flex;\n align-items: center;\n}\n.explorer-tree-row .row-item .row-item-content > input {\n height: 24px;\n outline: none;\n width: 100%;\n outline: 0;\n border: 0;\n}\n.explorer-tree-row .row-item-check {\n display: flex;\n width: 19px;\n align-items: center;\n box-sizing: border-box;\n pointer-events: all;\n}\n.explorer-tree-row .row-item-check .btn-check {\n display: inline-block;\n height: 19px;\n width: 19px;\n flex-shrink: 0;\n z-index: 11;\n font-size: 20px;\n text-align: center;\n border-radius: 50%;\n background: rgba(0, 0, 0, 0.05);\n color: #fff;\n line-height: 0;\n opacity: 0;\n cursor: pointer;\n transition: opacity 0.3s;\n margin: 2px;\n}\n.explorer-tree-row .row-item-check .btn-check > svg {\n position: relative;\n width: 23px;\n height: 23px;\n left: -2px;\n top: -2px;\n}\n.explorer-tree-row .row-item-check.active .btn-check {\n opacity: 1;\n background: #3b8cff;\n}\n.explorer-tree-row.disable {\n opacity: 0.4;\n}\n.explorer-tree.table .tree-scroll-x {\n width: 100%;\n overflow: hidden;\n overflow-x: auto;\n}\n.explorer-tree.table .tree-scroll-x::-webkit-scrollbar {\n display: none;\n}\n.explorer-tree.table .tree-scroll {\n position: absolute;\n left: 0;\n right: 0;\n top: 0;\n bottom: 0;\n z-index: 10;\n overflow: auto;\n}\n.explorer-tree.table .rc-tree {\n height: calc(100% - 26px);\n}\n.explorer-tree.table .rc-tree-list-holder-inner {\n overflow: auto;\n}\n.explorer-tree.table .rc-tree-list {\n height: 100%;\n}\n.explorer-tree.table .rc-tree-checkbox {\n display: none !important;\n}\n.explorer-tree.table .rc-tree-treenode {\n border-radius: 2px;\n width: fit-content;\n opacity: 0.8;\n z-index: 100;\n pointer-events: all;\n margin-bottom: 2px;\n}\n.explorer-tree.table .rc-tree-treenode.rc-tree-treenode-selected {\n background: #4581a60d !important;\n}\n.explorer-tree.table .rc-tree-treenode.odd {\n background: #4664780d;\n}\n.explorer-tree.table .rc-tree-list-holder-inner {\n padding: 8px 0 0 8px;\n}\n.explorer-tree.table .rc-tree-treenode-leaf-last:last-child {\n height: 200px;\n opacity: 0;\n width: 1px;\n}\n.explorer-tree.table .rc-tree-treenode-checkbox-checked {\n background: #cce8ff !important;\n border: 1px solid #99d1ff;\n}\n.explorer-tree .rc-tree-iconEle {\n height: 31px !important;\n vertical-align: top !important;\n width: auto !important;\n}\n.explorer-tree .rc-tree-treenode {\n position: relative;\n height: 31px;\n line-height: 31px;\n border: 1px solid transparent;\n user-select: none;\n display: flex;\n}\n.explorer-tree .rc-tree-treenode > .rc-tree-node-content-wrapper {\n height: 31px !important;\n display: flex !important;\n flex: 1;\n margin-left: calc(24px - 20px);\n overflow: hidden;\n}\n.explorer-tree .rc-tree-treenode > .rc-tree-node-selected {\n background-color: transparent;\n box-shadow: none;\n opacity: 1;\n}\n.explorer-tree .rc-tree-treenode.rc-tree-treenode-selected {\n background-color: #cce8ff !important;\n border: 1px solid #1890ff;\n opacity: 0.8;\n}\n.explorer-tree .rc-tree-treenode.rc-tree-treenode-selected .node-menu {\n display: flex;\n}\n.explorer-tree .rc-tree-treenode:hover {\n background: #e5f3ff !important;\n box-shadow: 0 0 0 1px transparent;\n}\n.explorer-tree .rc-tree-treenode.hover {\n background: #e5f3ff !important;\n}\n.explorer-tree .rc-tree-switcher {\n flex-shrink: 0;\n width: 20px !important;\n height: 31px !important;\n vertical-align: top !important;\n background-image: none !important;\n}\n.explorer-tree .rc-tree-title {\n display: inline-block;\n height: 31px;\n width: 100%;\n}\n.explorer-tree.showLine .rc-tree-indent {\n height: 31px;\n}\n.explorer-tree.showLine .rc-tree-indent > .rc-tree-indent-unit {\n position: relative;\n}\n.explorer-tree.showLine .rc-tree-indent > .rc-tree-indent-unit::after {\n display: inline-block;\n position: absolute;\n content: '';\n width: 1px;\n left: 10px;\n height: 31px;\n background-color: rgba(0, 0, 0, 0.075);\n}\n.explorer-tree.showLine .rc-tree-indent-unit {\n width: 20px;\n height: 31px;\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:last-child {\n position: relative;\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:last-child::before {\n content: '';\n display: inline-block;\n position: absolute;\n width: 8px;\n top: calc(31px / 2);\n left: 10px;\n height: 1px;\n background-color: rgba(0, 0, 0, 0.075);\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:last-child::after {\n display: inline-block;\n position: absolute;\n content: '';\n width: 1px;\n left: 10px;\n top: 0;\n height: calc(31px / 2);\n background-color: rgba(0, 0, 0, 0.075);\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:first-child {\n position: relative;\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:first-child::before {\n display: none;\n content: '';\n}\n.explorer-tree.showLine .rc-tree-treenode-leaf-last .rc-tree-indent > .rc-tree-indent-unit:first-child::after {\n display: inline-block;\n position: absolute;\n content: '';\n width: 1px;\n left: 10px;\n height: 31px;\n background-color: rgba(0, 0, 0, 0.075);\n}\n.explorer-tree.explorer-checks .rc-tree-treenode:hover .row-item-check .btn-check {\n opacity: 1;\n}\n.explorer-tree .rc-tree-list-scrollbar-thumb {\n background: #bbb !important;\n}\n.explorer-tree .rc-tree-list-scrollbar {\n width: 5px !important;\n}\n.explorer-tree .node-motion {\n transition: all 0.3s;\n overflow-y: hidden;\n}\n.explorer-tree .rc-tree-child-tree {\n display: block;\n}\n.explorer-table-header {\n display: flex;\n width: fit-content;\n min-width: 100%;\n height: 25px;\n line-height: 25px;\n color: #448;\n border-bottom: 1px solid #e3e3e3;\n box-shadow: 0 6px 10px rgba(0, 0, 0, 0.05);\n background: #fff;\n}\n.explorer-table-header .item {\n padding: 0 10px 0 0;\n flex: 1 0 0;\n margin-left: -10px;\n border-right: 1px solid #eee;\n user-select: none;\n min-width: 80px;\n}\n.explorer-table-header .item:first-child {\n padding-left: 20px;\n}\n.explorer-table-header .resize {\n position: relative;\n flex: 0 0 20px;\n width: 20px;\n z-index: 10;\n cursor: col-resize;\n left: -10px;\n transition: background 0.2s;\n}\n.explorer-table-header .resize::before {\n content: '';\n position: fixed;\n width: 1px;\n height: 2000px;\n z-index: 10;\n margin-left: 10px;\n visibility: hidden;\n opacity: 0;\n transition: all 0.2s;\n}\n.explorer-table-header .resize:hover {\n background: #1890ff30;\n}\n.explorer-table-header .resize.resize-focus {\n z-index: 9999;\n}\n.explorer-table-header .resize.resize-focus:before {\n opacity: 1;\n background: #1890ff;\n visibility: visible;\n}\n.explorer-table-header .resize:last-child {\n flex: 0 0 10px;\n width: 10px;\n}\n.explorer-table-header.item-resize {\n z-index: 10;\n}\n@keyframes rotate {\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(360deg);\n }\n}\n";
1624
1624
  styleInject(css_248z$8);
1625
1625
 
1626
1626
  /**
@@ -2401,7 +2401,8 @@ class InternalTreeNode extends React.Component {
2401
2401
  selected,
2402
2402
  icon,
2403
2403
  loading,
2404
- data
2404
+ data,
2405
+ index
2405
2406
  } = this.props;
2406
2407
  const {
2407
2408
  context: {
@@ -2428,7 +2429,7 @@ class InternalTreeNode extends React.Component {
2428
2429
  // Title
2429
2430
  let titleNode;
2430
2431
  if (typeof title === 'function') {
2431
- titleNode = title(data);
2432
+ titleNode = title(data, index);
2432
2433
  } else if (titleRender) {
2433
2434
  titleNode = titleRender(data);
2434
2435
  } else {
@@ -2508,6 +2509,7 @@ class InternalTreeNode extends React.Component {
2508
2509
  onMouseMove,
2509
2510
  selectable,
2510
2511
  indentWidth,
2512
+ index,
2511
2513
  ...otherProps
2512
2514
  } = this.props;
2513
2515
  const {
@@ -2547,6 +2549,7 @@ class InternalTreeNode extends React.Component {
2547
2549
  [`${prefixCls}-treenode-active`]: active,
2548
2550
  [`${prefixCls}-treenode-leaf-last`]: isEndNode,
2549
2551
  [`${prefixCls}-treenode-draggable`]: mergedDraggable,
2552
+ ['odd']: typeof index === 'number' ? index % 2 == 0 ? true : false : false,
2550
2553
  dragging,
2551
2554
  'drop-target': dropTargetKey === eventKey,
2552
2555
  'drop-container': dropContainerKey === eventKey,
@@ -2619,6 +2622,7 @@ const MotionTreeNode = ({
2619
2622
  onMotionEnd: onOriginMotionEnd,
2620
2623
  active,
2621
2624
  treeNodeRequiredProps,
2625
+ index,
2622
2626
  ...props
2623
2627
  }, ref) => {
2624
2628
  const [visible, setVisible] = React.useState(true);
@@ -2689,6 +2693,7 @@ const MotionTreeNode = ({
2689
2693
  active: active,
2690
2694
  data: treeNode.data,
2691
2695
  key: key,
2696
+ index: index,
2692
2697
  isStart: isStart,
2693
2698
  isEnd: isEnd
2694
2699
  });
@@ -2697,6 +2702,7 @@ const MotionTreeNode = ({
2697
2702
  });
2698
2703
  }
2699
2704
  return jsx(ContextTreeNode, {
2705
+ index: index,
2700
2706
  domRef: ref,
2701
2707
  className: className,
2702
2708
  style: style,
@@ -2974,7 +2980,7 @@ const NodeList = /*#__PURE__*/React.forwardRef((props, ref) => {
2974
2980
  onMotionEnd();
2975
2981
  }
2976
2982
  },
2977
- children: treeNode => {
2983
+ children: (treeNode, index) => {
2978
2984
  const {
2979
2985
  pos,
2980
2986
  data: {
@@ -3005,6 +3011,7 @@ const NodeList = /*#__PURE__*/React.forwardRef((props, ref) => {
3005
3011
  onMotionStart: onListChangeStart,
3006
3012
  onMotionEnd: onMotionEnd,
3007
3013
  treeNodeRequiredProps: treeNodeRequiredProps,
3014
+ index: index,
3008
3015
  onMouseMove: () => {
3009
3016
  onActiveChange(null);
3010
3017
  }
@@ -5304,10 +5311,16 @@ function TableItem(props) {
5304
5311
  loadMenu,
5305
5312
  ...param
5306
5313
  } = props;
5314
+ let disable = false;
5315
+ if (Array.isArray(props.selectedSuffix)) {
5316
+ disable = !props.selectedSuffix.includes(props.suffix) && !props.selectedSuffix?.includes(props?.type);
5317
+ }
5307
5318
  return jsx("div", {
5308
- className: cx$1('explorer-tree-row'),
5309
- "data-id": id,
5310
- "data-type": props.type,
5319
+ className: cx$1('explorer-tree-row', {
5320
+ disable
5321
+ }),
5322
+ "data-id": !disable ? id : null,
5323
+ "data-type": !disable ? props.type : null,
5311
5324
  onContextMenu: e => {
5312
5325
  e.stopPropagation();
5313
5326
  e.preventDefault();
@@ -5443,6 +5456,7 @@ function TableItem(props) {
5443
5456
  e.stopPropagation();
5444
5457
  },
5445
5458
  onClick: e => {
5459
+ if (disable) return;
5446
5460
  e.stopPropagation();
5447
5461
  e.preventDefault();
5448
5462
  onCheck?.();
@@ -6164,7 +6178,7 @@ const ExplorerMenu = props => {
6164
6178
  });
6165
6179
  };
6166
6180
 
6167
- var css_248z$4 = ".file-continer-main {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n}\n.file-continer-main .file-continer {\n position: absolute;\n overflow-x: hidden;\n overflow-y: auto;\n left: 0;\n top: 0;\n right: 0;\n bottom: 0;\n padding: 0;\n}\n.file-continer-main .file-continer .path-is-null {\n text-align: center;\n color: #bbb;\n position: absolute;\n left: 50%;\n top: 50%;\n width: 200px;\n height: 200px;\n margin-top: -140px;\n margin-left: -100px;\n font-size: 0.9em;\n}\n.file-continer-main .file-continer .path-is-null .path-ico {\n width: 200px;\n height: 140px;\n display: block;\n font-size: 18px;\n vertical-align: text-bottom;\n}\n.file-continer-main .file-continer .path-is-null .path-ico img {\n width: 200px;\n height: auto;\n max-width: 100%;\n max-height: 100%;\n}\n.file-continer-main .file-continer .path-is-null .text {\n background: rgba(160, 160, 160, 0.1);\n padding: 3px 10px;\n border-radius: 10px;\n}\n.file-continer-main .file-select-box {\n width: 100%;\n height: 100%;\n}\n.file {\n position: absolute;\n border-radius: 0;\n filter: none;\n transition: transform 0.2s;\n border: 1px solid transparent;\n padding: 0px;\n box-shadow: 0 0 2px rgba(255, 255, 255, 0);\n transition: background 0.2s, border 0.2s, color 0.2s;\n text-decoration: none;\n overflow: hidden;\n text-align: center;\n box-sizing: border-box;\n display: inline-block;\n margin: 0;\n height: auto;\n vertical-align: top;\n user-select: none;\n}\n.file * {\n box-sizing: content-box;\n}\n.file.file-focus {\n border-color: #4daeff;\n background: #b5deff3d;\n}\n.file:hover {\n border-color: transparent;\n background: #e5f3ff;\n}\n.file.select {\n border-color: #4daeff;\n background: #cce8ff;\n}\n.file.hover {\n background: #cce8ff;\n}\n.file .path-ico {\n text-align: center;\n display: inline-block;\n vertical-align: text-bottom;\n}\n.file .path-ico .explorer-label-icon {\n padding: 10px;\n}\n.file .path-ico .x-item-icon {\n height: 79px;\n width: 79px;\n font-size: 79px;\n margin-top: 5px;\n background-repeat: no-repeat;\n background-position: center;\n background-size: cover;\n width: 100%;\n height: 100%;\n border-radius: 5px;\n font-style: normal;\n display: inline-block;\n pointer-events: none;\n}\n.file .path-ico .x-item-icon > svg {\n padding: 0 5px;\n}\n.file .path-ico .x-item-icon.x-folder {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-xls {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-xlsx {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-doc {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-docx {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-pptx {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-md {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-txt {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-js {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-css {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-html {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-json {\n background-image: url('');\n}\n.file .path-ico img {\n transform: scale(0.8);\n}\n.file .path-ico .picture {\n width: 79px;\n height: 79px;\n margin-top: 2px;\n position: relative;\n transition: all 0.168s;\n}\n.file .path-ico .picture:after {\n position: absolute;\n left: 0;\n width: 100%;\n height: 100%;\n background: transparent;\n content: '';\n}\n.file .path-ico .picture .picture-show {\n max-height: 100%;\n max-width: 100%;\n border-radius: 2px;\n transition: all 0.2s ease;\n background: #fff;\n object-fit: cover;\n position: absolute;\n margin: auto;\n left: 0;\n top: 0;\n right: 0;\n bottom: 0;\n box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.2);\n user-select: none;\n pointer-events: none;\n}\n.file .title-type-name {\n box-sizing: border-box;\n cursor: default;\n text-align: center;\n word-break: break-word;\n margin: 0 auto;\n padding: 5px 2px 5px 2px;\n color: #444;\n line-height: 20px;\n font-size: 1em;\n}\n.file .title-type-name .title {\n display: inline-block;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 3;\n overflow: hidden;\n position: relative;\n display: -webkit-box;\n}\n.file .title-type-name textarea {\n width: calc(100% - 6px);\n border: 0;\n outline: 0;\n resize: none;\n line-height: 18px;\n}\n";
6181
+ var css_248z$4 = ".file-continer-main {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n}\n.file-continer-main .file-continer {\n position: absolute;\n overflow-x: hidden;\n overflow-y: auto;\n left: 0;\n top: 0;\n right: 0;\n bottom: 0;\n padding: 0;\n}\n.file-continer-main .file-continer .path-is-null {\n text-align: center;\n color: #bbb;\n position: absolute;\n left: 50%;\n top: 50%;\n width: 200px;\n height: 200px;\n margin-top: -140px;\n margin-left: -100px;\n font-size: 0.9em;\n}\n.file-continer-main .file-continer .path-is-null .path-ico {\n width: 200px;\n height: 140px;\n display: block;\n font-size: 18px;\n vertical-align: text-bottom;\n}\n.file-continer-main .file-continer .path-is-null .path-ico img {\n width: 200px;\n height: auto;\n max-width: 100%;\n max-height: 100%;\n}\n.file-continer-main .file-continer .path-is-null .text {\n background: rgba(160, 160, 160, 0.1);\n padding: 3px 10px;\n border-radius: 10px;\n}\n.file-continer-main .file-select-box {\n width: 100%;\n height: 100%;\n}\n.file {\n position: absolute;\n border-radius: 0;\n filter: none;\n transition: transform 0.2s;\n border: 1px solid transparent;\n padding: 0px;\n box-shadow: 0 0 2px rgba(255, 255, 255, 0);\n transition: background 0.2s, border 0.2s, color 0.2s;\n text-decoration: none;\n overflow: hidden;\n text-align: center;\n box-sizing: border-box;\n display: inline-block;\n margin: 0;\n height: auto;\n vertical-align: top;\n user-select: none;\n}\n.file * {\n box-sizing: content-box;\n}\n.file.disable {\n opacity: 0.4;\n}\n.file.file-focus {\n border-color: #4daeff;\n background: #b5deff3d;\n}\n.file:hover {\n border-color: transparent;\n background: #e5f3ff;\n}\n.file.select {\n border-color: #4daeff;\n background: #cce8ff;\n}\n.file.hover {\n background: #cce8ff;\n}\n.file .path-ico {\n text-align: center;\n display: inline-block;\n vertical-align: text-bottom;\n}\n.file .path-ico .explorer-label-icon {\n padding: 10px;\n}\n.file .path-ico .x-item-icon {\n height: 79px;\n width: 79px;\n font-size: 79px;\n margin-top: 5px;\n background-repeat: no-repeat;\n background-position: center;\n background-size: cover;\n width: 100%;\n height: 100%;\n border-radius: 5px;\n font-style: normal;\n display: inline-block;\n pointer-events: none;\n}\n.file .path-ico .x-item-icon > svg {\n padding: 0 5px;\n}\n.file .path-ico .x-item-icon.x-folder {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-xls {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-xlsx {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-doc {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-docx {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-pptx {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-md {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-txt {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-js {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-css {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-html {\n background-image: url('');\n}\n.file .path-ico .x-item-icon.x-json {\n background-image: url('');\n}\n.file .path-ico img {\n transform: scale(0.8);\n}\n.file .path-ico .picture {\n width: 79px;\n height: 79px;\n margin-top: 2px;\n position: relative;\n transition: all 0.168s;\n}\n.file .path-ico .picture:after {\n position: absolute;\n left: 0;\n width: 100%;\n height: 100%;\n background: transparent;\n content: '';\n}\n.file .path-ico .picture .picture-show {\n max-height: 100%;\n max-width: 100%;\n border-radius: 2px;\n transition: all 0.2s ease;\n background: #fff;\n object-fit: cover;\n position: absolute;\n margin: auto;\n left: 0;\n top: 0;\n right: 0;\n bottom: 0;\n box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.2);\n user-select: none;\n pointer-events: none;\n}\n.file .title-type-name {\n box-sizing: border-box;\n cursor: default;\n text-align: center;\n word-break: break-word;\n margin: 0 auto;\n padding: 5px 2px 5px 2px;\n color: #444;\n line-height: 20px;\n font-size: 1em;\n}\n.file .title-type-name .title {\n display: inline-block;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 3;\n overflow: hidden;\n position: relative;\n display: -webkit-box;\n}\n.file .title-type-name textarea {\n width: calc(100% - 6px);\n border: 0;\n outline: 0;\n resize: none;\n line-height: 18px;\n}\n";
6168
6182
  styleInject(css_248z$4);
6169
6183
 
6170
6184
  const VirtualScroll = ({
@@ -6294,15 +6308,21 @@ function Tile(props) {
6294
6308
  menudata = getMenu('');
6295
6309
  }
6296
6310
  let isname = rename == v.key || v?.create_file;
6311
+ let disable = false;
6312
+ //判断是否可以选中 选中的逻辑在 select-box 中 可以控制 data-id 进行编辑
6313
+ if (Array.isArray(store.selectedSuffix)) {
6314
+ disable = !store.selectedSuffix?.includes(v?.suffix) && !store.selectedSuffix?.includes(v?.type);
6315
+ }
6297
6316
  return jsxs("div", {
6298
- "data-id": v.key,
6299
- "data-type": v.type,
6317
+ "data-id": !disable ? v.key : undefined,
6318
+ "data-type": !disable ? v.type : undefined,
6300
6319
  className: cx$1('file', {
6301
6320
  'file-folder': v.type === 'folder',
6302
6321
  'menu-path-folder': v.type === 'folder',
6303
6322
  'menu-path-file': v.type === 'file',
6304
6323
  select: !!~checks.indexOf(v.key) || isname,
6305
- 'file-focus': focus === v.key
6324
+ 'file-focus': focus === v.key,
6325
+ disable
6306
6326
  }, css(_t$1 || (_t$1 = _$1`
6307
6327
  top: ${0}px;
6308
6328
  left: ${0}px;
@@ -6310,6 +6330,7 @@ function Tile(props) {
6310
6330
  max-height: ${0}px;
6311
6331
  `), (w + 65) * index + index * 10 + 10, w * i + i * 10 + 10, w || 0, w + 65)),
6312
6332
  onClick: e => {
6333
+ if (disable) return;
6313
6334
  e.stopPropagation();
6314
6335
  if (select && focus == v.key) return;
6315
6336
  onSelect?.(v.key, v);
@@ -6383,7 +6404,7 @@ function Tile(props) {
6383
6404
  onRename?.(v.key, e.target?.value, v);
6384
6405
  }
6385
6406
  if (e.key === 'Escape') {
6386
- onRename?.(v.key, false, v);
6407
+ setRename(null);
6387
6408
  return;
6388
6409
  }
6389
6410
  },
@@ -6508,6 +6529,7 @@ const SelectBox = props => {
6508
6529
  document.removeEventListener('mouseup', handleBodyMouseup);
6509
6530
  };
6510
6531
  }, [stageClickInfo, checkMode]);
6532
+ /***************** 方法 ******************/
6511
6533
  //判断鼠标点击位置 是否为目标区域
6512
6534
  function isSelectTarget(e, checkType, status) {
6513
6535
  let idx = [];
@@ -6542,6 +6564,15 @@ const SelectBox = props => {
6542
6564
  }
6543
6565
  return null;
6544
6566
  }
6567
+ //清空
6568
+ function empty() {
6569
+ target.current?.remove();
6570
+ box.current?.remove();
6571
+ target.current = null;
6572
+ box.current = null;
6573
+ clickRef.current = false;
6574
+ }
6575
+ /***************** 鼠标移动 ******************/
6545
6576
  //鼠标移动
6546
6577
  function handleBodyMousemove(e) {
6547
6578
  const {
@@ -6603,7 +6634,7 @@ const SelectBox = props => {
6603
6634
  }, 300);
6604
6635
  }
6605
6636
  }
6606
- /*** 拖动 ***/
6637
+ /***************** 拖动 *****************/
6607
6638
  //拖动文件
6608
6639
  const handleDragOver = e => {
6609
6640
  e.preventDefault();
@@ -6640,6 +6671,7 @@ const SelectBox = props => {
6640
6671
  text.current.render(element);
6641
6672
  }
6642
6673
  };
6674
+ //文件上传
6643
6675
  const handleDrop = async e => {
6644
6676
  setIsDragFile(false);
6645
6677
  e.preventDefault();
@@ -6726,7 +6758,7 @@ const SelectBox = props => {
6726
6758
  }
6727
6759
  setIsDragFile(true);
6728
6760
  }
6729
- /****** 创建绘制页面 *******/
6761
+ /*********** 创建绘制页面 *************/
6730
6762
  //创建文案
6731
6763
  function createText() {
6732
6764
  let _box = null;
@@ -6755,7 +6787,7 @@ const SelectBox = props => {
6755
6787
  body?.appendChild(_box);
6756
6788
  }
6757
6789
  }
6758
- //创建选框
6790
+ //创建选框 并过滤 数据
6759
6791
  function createBox(e) {
6760
6792
  if (stageClickInfo.show) {
6761
6793
  let region = null;
@@ -6872,14 +6904,6 @@ const SelectBox = props => {
6872
6904
  }
6873
6905
  }
6874
6906
  }
6875
- //清空
6876
- function empty() {
6877
- target.current?.remove();
6878
- box.current?.remove();
6879
- target.current = null;
6880
- box.current = null;
6881
- clickRef.current = false;
6882
- }
6883
6907
  function renderDragtext({
6884
6908
  x,
6885
6909
  y,
@@ -6911,6 +6935,71 @@ const SelectBox = props => {
6911
6935
  })
6912
6936
  });
6913
6937
  }
6938
+ /************* shift 选中 **************/
6939
+ //分栏模式下特殊处理
6940
+ function shiftSelectColumns(start, end) {
6941
+ let _start = store.dataMap?.[start]?.level || '';
6942
+ let _end = store.dataMap?.[end]?.level || '';
6943
+ if (!_end) return;
6944
+ let start_level = _start?.split('-');
6945
+ let end_level = _end?.split('-');
6946
+ let is = end_level.length == start_level.length;
6947
+ //开始位置
6948
+ let start_position = start_level[start_level.length - 1] ? start_level[start_level.length - 1] - 0 : 0;
6949
+ // 结束位置
6950
+ let end_position = end_level[end_level.length - 1] ? end_level[end_level.length - 1] - 0 : 0;
6951
+ let max = start_position > end_position ? start_position : end_position;
6952
+ let min = start_position > end_position ? end_position : start_position;
6953
+ //判断是否是同一层
6954
+ if (!is) {
6955
+ min = 0;
6956
+ }
6957
+ let ids = [];
6958
+ const addLevel = data => {
6959
+ if (!data) return;
6960
+ let i = 0;
6961
+ while (i < data.length) {
6962
+ let item = data[i];
6963
+ if (typeof item.level === 'string') {
6964
+ let arr = item.level.split('-');
6965
+ let curIndex = arr[arr.length - 1];
6966
+ if (end_level.length == arr.length) {
6967
+ if (curIndex >= min && curIndex <= max) {
6968
+ ids.push(item.key);
6969
+ }
6970
+ }
6971
+ }
6972
+ if (Array.isArray(item.children) && item.children.length > 0) {
6973
+ addLevel(item.children);
6974
+ }
6975
+ i++;
6976
+ }
6977
+ };
6978
+ addLevel(store?.curlist || []);
6979
+ setSelect(ids);
6980
+ onChange(ids);
6981
+ }
6982
+ function shiftSelect(start, end) {
6983
+ if (!store?.dataMap) return;
6984
+ let _start = store.dataMap?.[start]?.index || 0;
6985
+ let _end = store.dataMap?.[end]?.index;
6986
+ if (typeof _end !== 'number') return;
6987
+ if (store?.menutype == 'column') {
6988
+ shiftSelectColumns(start, end);
6989
+ return;
6990
+ }
6991
+ let max = _start > _end ? _start : _end;
6992
+ let min = _start > _end ? _end : _start;
6993
+ let data = Object.values(store?.dataMap);
6994
+ let ids = [];
6995
+ data.map(v => {
6996
+ if (v.index >= min && v.index <= max) {
6997
+ ids.push(v.key);
6998
+ }
6999
+ });
7000
+ setSelect(ids);
7001
+ onChange(ids);
7002
+ }
6914
7003
  return jsxs("div", {
6915
7004
  ref: ref,
6916
7005
  className: cx$1(`file-select-box ${className}`),
@@ -6922,6 +7011,28 @@ const SelectBox = props => {
6922
7011
  },
6923
7012
  onMouseDown: e => {
6924
7013
  let type = isSelectTarget(e, checkType);
7014
+ //按下shift建 切有 起始 选中文件
7015
+ if (store.shift && type?.[0]) {
7016
+ shiftSelect(checks[0], type[0]);
7017
+ return;
7018
+ }
7019
+ if (store.control && type?.[0]) {
7020
+ if (checks.includes(type?.[0])) {
7021
+ let arr = [];
7022
+ arr = checks.filter(v => v !== type?.[0]);
7023
+ setSelect(arr);
7024
+ onChange(arr);
7025
+ } else {
7026
+ let arr = [];
7027
+ if (!checks.includes(type?.[0])) {
7028
+ arr = [...selects, ...type];
7029
+ setSelect(arr);
7030
+ onChange(arr);
7031
+ return;
7032
+ }
7033
+ }
7034
+ return;
7035
+ }
6925
7036
  if (checks.includes(type?.[0])) {
6926
7037
  //右键不能今天拖动
6927
7038
  if (e.button === 2) return;
@@ -7013,18 +7124,18 @@ const SelectBox = props => {
7013
7124
  });
7014
7125
  };
7015
7126
 
7016
- var css_248z$2 = ".explorer-columns {\n width: 100%;\n height: 100%;\n display: flex;\n position: relative;\n}\n.explorer-columns .layer {\n position: relative;\n flex: 1 0 0;\n border-right: 1px solid #f5f5f5;\n}\n.explorer-columns .layer.select_col {\n box-shadow: 0 0 20px #e9f5ff inset;\n}\n.explorer-columns .layer.select_col::after {\n content: '';\n position: absolute;\n height: 4px;\n bottom: 0px;\n background: #50afff;\n left: 0;\n right: 0;\n}\n.explorer-columns .layer.list {\n min-width: 200px;\n}\n.explorer-columns .layer.list::before {\n position: absolute;\n content: '';\n top: 50%;\n right: 1px;\n width: 1px;\n height: 18px;\n margin-left: -1px;\n margin-top: -9px;\n border: 1px solid #ddd;\n border-top: none;\n border-bottom: none;\n backdrop-filter: none;\n border-radius: 0;\n background: transparent;\n box-sizing: content-box;\n -webkit-backdrop-filter: blur(10px);\n}\n.explorer-columns .layer.list .list-main {\n width: 100%;\n height: 100%;\n transition: 0.3s;\n padding-top: 5px;\n}\n.explorer-columns .layer.list .list-main .list-scroll::-webkit-scrollbar {\n width: 6px;\n}\n.explorer-columns .layer.list .list-main .list-scroll::-webkit-scrollbar-thumb {\n background-color: transparent;\n border-radius: 6px;\n transition: 0.3s;\n}\n.explorer-columns .layer.list .list-main:hover .list-scroll::-webkit-scrollbar-thumb {\n background-color: #00000030;\n}\n.explorer-columns .layer.list .drag {\n position: absolute;\n width: 8px;\n border-right: 1px solid #f5f5f5;\n right: -3px;\n top: 0;\n bottom: 0;\n cursor: col-resize;\n z-index: 10;\n}\n.explorer-columns .layer.list .drag:hover {\n background: #40a9ff4d;\n}\n.explorer-columns .layer.empty {\n display: flex;\n justify-content: center;\n padding-top: 100px;\n}\n.explorer-columns .layer.empty .empty-is-null {\n width: 200px;\n}\n.explorer-columns .layer.empty .empty-icon {\n height: 140px;\n}\n.explorer-columns .layer.empty .empty-desc {\n display: flex;\n justify-content: center;\n}\n.explorer-columns .layer.empty .empty-desc > span {\n display: inline-block;\n padding: 3px 10px;\n border-radius: 10px;\n line-height: 1;\n background: #a0a0a01a;\n color: #bbb;\n font-size: 0.9em;\n}\n.explorer-columns-list {\n padding-left: 10px;\n display: flex;\n height: 30px;\n margin-bottom: 2px;\n margin: 0 5px 3px 5px;\n align-items: center;\n border: 1px solid transparent;\n user-select: none;\n overflow: hidden;\n}\n.explorer-columns-list .columns-list-icon {\n display: flex;\n width: 18px;\n height: 18px;\n margin-right: 10px;\n flex-shrink: 0;\n}\n.explorer-columns-list .columns-list-title {\n width: 100%;\n display: inline-block;\n width: calc(100% - 30px);\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n.explorer-columns-list .columns-list-tool {\n min-width: 30px;\n}\n.explorer-columns-list .columns-list-input {\n flex: 1;\n height: 100%;\n outline: 0;\n border: 0;\n margin-right: 10px;\n background: #fff;\n}\n.explorer-columns-list.acitve {\n background: #e3f0ff;\n}\n.explorer-columns-list.last {\n margin-bottom: 100px;\n}\n.explorer-columns-list.checks {\n background: #cce8ff;\n border-color: #a8d8ff !important;\n}\n.explorer-columns-list:hover {\n background: #e3f0ff;\n border-color: #c9e2ff;\n}\n.explorer-columns-list:hover .edit {\n opacity: 1;\n}\n.explorer-columns-loading {\n position: absolute;\n display: flex;\n justify-content: center;\n align-items: center;\n z-index: 999;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n}\n.explorer-columns-loading .loading-content {\n width: 100px;\n height: 106px;\n border-radius: 6px;\n background: rgba(255, 255, 255, 0.7);\n box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.07);\n color: #888;\n}\n.explorer-columns-loading .loading-content-icon {\n display: flex;\n justify-content: center;\n margin: 25px auto 6px auto;\n font-size: 30px;\n}\n.explorer-columns-loading .loading-content-icon > i {\n animation: rotate 1.5s linear infinite;\n}\n.explorer-columns-loading .loading-content-title {\n padding-top: 15px;\n text-align: center;\n}\n@keyframes rotate {\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(360deg);\n }\n}\n";
7127
+ var css_248z$2 = ".explorer-columns {\n width: 100%;\n height: 100%;\n display: flex;\n position: relative;\n overflow: auto;\n}\n.explorer-columns .layer {\n position: relative;\n flex: 1 0 0;\n border-right: 1px solid #f5f5f5;\n}\n.explorer-columns .layer.select_col {\n box-shadow: 0 0 20px #e9f5ff inset;\n}\n.explorer-columns .layer.select_col::after {\n content: '';\n position: absolute;\n height: 4px;\n bottom: 0px;\n background: #50afff;\n left: 0;\n right: 0;\n}\n.explorer-columns .layer.list {\n min-width: 200px;\n}\n.explorer-columns .layer.list::before {\n position: absolute;\n content: '';\n top: 50%;\n right: 1px;\n width: 1px;\n height: 18px;\n margin-left: -1px;\n margin-top: -9px;\n border: 1px solid #ddd;\n border-top: none;\n border-bottom: none;\n backdrop-filter: none;\n border-radius: 0;\n background: transparent;\n box-sizing: content-box;\n -webkit-backdrop-filter: blur(10px);\n}\n.explorer-columns .layer.list .list-main {\n width: 100%;\n height: 100%;\n transition: 0.3s;\n padding-top: 5px;\n}\n.explorer-columns .layer.list .list-main .list-scroll::-webkit-scrollbar {\n width: 6px;\n}\n.explorer-columns .layer.list .list-main .list-scroll::-webkit-scrollbar-thumb {\n background-color: transparent;\n border-radius: 6px;\n transition: 0.3s;\n}\n.explorer-columns .layer.list .list-main:hover .list-scroll::-webkit-scrollbar-thumb {\n background-color: #00000030;\n}\n.explorer-columns .layer.list .drag {\n position: absolute;\n width: 8px;\n border-right: 1px solid #f5f5f5;\n right: -3px;\n top: 0;\n bottom: 0;\n cursor: col-resize;\n z-index: 10;\n}\n.explorer-columns .layer.list .drag:hover {\n background: #40a9ff4d;\n}\n.explorer-columns .layer.empty {\n display: flex;\n justify-content: center;\n padding-top: 100px;\n}\n.explorer-columns .layer.empty .empty-is-null {\n width: 200px;\n}\n.explorer-columns .layer.empty .empty-icon {\n height: 140px;\n}\n.explorer-columns .layer.empty .empty-desc {\n display: flex;\n justify-content: center;\n}\n.explorer-columns .layer.empty .empty-desc > span {\n display: inline-block;\n padding: 3px 10px;\n border-radius: 10px;\n line-height: 1;\n background: #a0a0a01a;\n color: #bbb;\n font-size: 0.9em;\n}\n.explorer-columns-list {\n padding-left: 10px;\n display: flex;\n height: 30px;\n margin-bottom: 2px;\n margin: 0 5px 3px 5px;\n align-items: center;\n border: 1px solid transparent;\n user-select: none;\n overflow: hidden;\n}\n.explorer-columns-list .columns-list-icon {\n display: flex;\n width: 18px;\n height: 18px;\n margin-right: 10px;\n flex-shrink: 0;\n}\n.explorer-columns-list .columns-list-title {\n width: 100%;\n display: inline-block;\n width: calc(100% - 30px);\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n.explorer-columns-list .columns-list-tool {\n min-width: 30px;\n}\n.explorer-columns-list .columns-list-input {\n flex: 1;\n height: 100%;\n outline: 0;\n border: 0;\n margin-right: 10px;\n background: #fff;\n}\n.explorer-columns-list.acitve {\n background: #e3f0ff;\n}\n.explorer-columns-list.last {\n margin-bottom: 100px;\n}\n.explorer-columns-list.checks {\n background: #cce8ff;\n border-color: #a8d8ff !important;\n}\n.explorer-columns-list.isedit {\n background: #cce8ff;\n border-color: #a8d8ff !important;\n}\n.explorer-columns-list:hover {\n background: #e3f0ff;\n border-color: #c9e2ff;\n}\n.explorer-columns-list:hover .edit {\n opacity: 1;\n}\n.explorer-columns-loading {\n position: absolute;\n display: flex;\n justify-content: center;\n align-items: center;\n z-index: 999;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n}\n.explorer-columns-loading .loading-content {\n width: 100px;\n height: 106px;\n border-radius: 6px;\n background: rgba(255, 255, 255, 0.7);\n box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.07);\n color: #888;\n}\n.explorer-columns-loading .loading-content-icon {\n display: flex;\n justify-content: center;\n margin: 25px auto 6px auto;\n font-size: 30px;\n}\n.explorer-columns-loading .loading-content-icon > i {\n animation: rotate 1.5s linear infinite;\n}\n.explorer-columns-loading .loading-content-title {\n padding-top: 15px;\n text-align: center;\n}\n.explorer-columns.notdata .explorer-notdata {\n width: 100%;\n}\n@keyframes rotate {\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(360deg);\n }\n}\n";
7017
7128
  styleInject(css_248z$2);
7018
7129
 
7019
7130
  function Item(props) {
7020
7131
  const {
7132
+ store,
7021
7133
  onClick,
7022
7134
  acitve,
7023
7135
  isedit,
7024
- onEdit,
7025
- onBlur,
7026
7136
  checks = false,
7027
- icon
7137
+ icon,
7138
+ parent
7028
7139
  } = props;
7029
7140
  const [value, setValue] = useState('');
7030
7141
  useEffect(() => {
@@ -7034,31 +7145,97 @@ function Item(props) {
7034
7145
  className: cx$1('explorer-columns-list', {
7035
7146
  last: props?.end,
7036
7147
  acitve: acitve,
7037
- checks: checks
7148
+ checks: checks,
7149
+ isedit: isedit
7038
7150
  }),
7039
7151
  "data-id": props.id,
7040
7152
  "data-type": props.type,
7041
7153
  onClick: onClick,
7042
7154
  onContextMenu: e => {
7043
7155
  e.preventDefault();
7156
+ e.stopPropagation();
7157
+ let x = 0;
7158
+ let y = 0;
7159
+ x = e.nativeEvent.clientX + 5;
7160
+ y = e.nativeEvent.clientY + 5;
7161
+ if (props?.menu == false) return;
7162
+ let menudata = [];
7163
+ if (getMenu(props.id)) {
7164
+ menudata = getMenu(props.id);
7165
+ } else if (props.type && getMenu(props.type)) {
7166
+ menudata = getMenu('nav-folder');
7167
+ } else {
7168
+ menudata = getMenu('');
7169
+ }
7170
+ store?.openMenu({
7171
+ x,
7172
+ y,
7173
+ content: jsx(Menu, {
7174
+ store: store,
7175
+ menu: menudata,
7176
+ loadMenu: props?.loadMenu,
7177
+ onChange: async key => {
7178
+ if (key == 'rename') {
7179
+ store?.setReName(props.id);
7180
+ return;
7181
+ }
7182
+ props?.onMenuClick?.(key, props);
7183
+ store?.closeMenu();
7184
+ }
7185
+ })
7186
+ }, {
7187
+ key: props.id
7188
+ });
7044
7189
  },
7045
7190
  children: [icon && icon?.(props, 'columns-list-icon'), isedit ? jsx("input", {
7046
7191
  className: 'columns-list-input',
7047
7192
  autoFocus: true,
7048
7193
  value: value,
7049
- onChange: e => {
7050
- setValue(e.target.value);
7051
- },
7052
7194
  onFocus: e => {
7053
- let i = value.lastIndexOf('.');
7195
+ let i = props.title.lastIndexOf('.');
7054
7196
  if (props?.suffix == 'folder') {
7055
- e.target.setSelectionRange(0, value.length);
7197
+ e.target.setSelectionRange(0, props.title.length);
7056
7198
  } else if (i !== -1) {
7057
7199
  e.target.setSelectionRange(0, i);
7058
7200
  }
7059
7201
  },
7202
+ onKeyDown: e => {
7203
+ if (e.key === 'Enter' || e.keyCode === 13) {
7204
+ if (props?.create_file) {
7205
+ props?.onRename?.(props.id, e.target?.value, {
7206
+ ...props,
7207
+ ...(parent || {}),
7208
+ create_file: true
7209
+ });
7210
+ return;
7211
+ }
7212
+ props?.onRename?.(props.id, e.target?.value, props);
7213
+ }
7214
+ if (e.key === 'Escape') {
7215
+ if (props.create_file) {
7216
+ props?.onRename(props.id, false, props);
7217
+ }
7218
+ store?.setReName?.(null);
7219
+ return;
7220
+ }
7221
+ },
7060
7222
  onBlur: e => {
7061
- onBlur?.(e);
7223
+ if (props?.create_file) {
7224
+ props?.onRename?.(props.id, e.target?.value, {
7225
+ create_file: true,
7226
+ ...(parent || {})
7227
+ });
7228
+ return;
7229
+ }
7230
+ if (e.target?.value === props.title) {
7231
+ store?.setReName?.(null);
7232
+ return;
7233
+ }
7234
+ props?.onRename?.(props.id, e.target.value, props);
7235
+ store?.setReName?.(null);
7236
+ },
7237
+ onChange: e => {
7238
+ setValue(e.target.value);
7062
7239
  }
7063
7240
  }) : jsxs(Fragment, {
7064
7241
  children: [jsx("div", {
@@ -7074,32 +7251,100 @@ function Item(props) {
7074
7251
  });
7075
7252
  }
7076
7253
  function Columns(props) {
7077
- let {
7254
+ const {
7255
+ store,
7078
7256
  width: _w,
7079
7257
  data,
7080
7258
  className,
7081
7259
  checks = [],
7082
7260
  icons,
7083
7261
  onLoadData,
7084
- onRename
7262
+ onChange
7085
7263
  } = props;
7086
7264
  const ref = useRef(null);
7087
7265
  const [layer, setLayer] = useState(new Array(6).fill([])); //文件列表数据
7088
7266
  const [width, setWidth] = useState(new Array(6).fill(null)); //记录每行的宽度
7089
7267
  const [select_col, setSelectCol] = useState(0); //选中栏
7090
- const [select_file, setSelectFile] = useState(new Array(6).fill(null)); //选中的文件
7091
7268
  const [select_info, setSelectInfo] = useState(''); //当前选中 key
7092
- const [edit, setEdit] = useState('');
7093
7269
  const [isdrag, setIsdarg] = useState(false);
7094
7270
  useEffect(() => {
7095
- let arr = new Array(6).fill([]);
7096
- arr[0] = data;
7097
- setLayer(arr);
7098
- }, [data]);
7271
+ let arr = new Array(6).fill('');
7272
+ //清空
7273
+ store.setExpandkey(arr);
7274
+ }, [store.curInfo.key]);
7275
+ useEffect(() => {
7276
+ initdata();
7277
+ }, [data, store.expandkey]);
7278
+ useEffect(() => {
7279
+ let level = select_col;
7280
+ store.setCurSelectFile(store.expandkey?.[level - 1] || null);
7281
+ }, [select_col, store?.expandkey]);
7099
7282
  let avg = useMemo(() => {
7100
7283
  if (!_w) return 0;
7101
7284
  return Math.ceil(_w / 6);
7102
7285
  }, [_w]);
7286
+ async function initdata() {
7287
+ let arr = new Array(6).fill([]);
7288
+ let {
7289
+ layer,
7290
+ isApi,
7291
+ child
7292
+ } = await getRowData(data, store.expandkey, 0);
7293
+ arr = layer;
7294
+ if (isApi) {
7295
+ onChange(child);
7296
+ }
7297
+ setLayer(arr);
7298
+ }
7299
+ async function getRowData(data, setSelectFile, level) {
7300
+ // 1. 返回 没层用到的数据
7301
+ // 2. 返回 是否调用接口
7302
+ // 3. 如果掉调用借口 需要记录 数据给到 children 上
7303
+ let arr = new Array(6).fill([]);
7304
+ let api = false;
7305
+ let child = [];
7306
+ if (Array.isArray(data)) {
7307
+ child = await Promise.all(data.map(async v => {
7308
+ if (setSelectFile?.[level] && v.key == setSelectFile[level]) {
7309
+ if (Array.isArray(v?.children)) {
7310
+ let {
7311
+ layer,
7312
+ isApi
7313
+ } = await getRowData(v.children, setSelectFile, level + 1);
7314
+ arr = layer;
7315
+ api = isApi;
7316
+ return v;
7317
+ } else {
7318
+ let data = await onLoadData?.(v.key);
7319
+ let _child = [];
7320
+ if (Array.isArray(data) && data.length) {
7321
+ api = true;
7322
+ let {
7323
+ layer,
7324
+ child
7325
+ } = await getRowData(data, setSelectFile, level + 1);
7326
+ _child = child;
7327
+ arr = layer;
7328
+ } else {
7329
+ arr[level + 1] = null;
7330
+ data = null;
7331
+ }
7332
+ return {
7333
+ ...v,
7334
+ children: _child
7335
+ };
7336
+ }
7337
+ }
7338
+ return v;
7339
+ }));
7340
+ }
7341
+ arr[level] = data;
7342
+ return {
7343
+ layer: arr,
7344
+ isApi: api,
7345
+ child
7346
+ };
7347
+ }
7103
7348
  useEffect(() => {
7104
7349
  let w = cloneDeep(width);
7105
7350
  layer.forEach((v, i) => {
@@ -7111,7 +7356,6 @@ function Columns(props) {
7111
7356
  }, [layer, avg]);
7112
7357
  function handleMousemove(e) {
7113
7358
  if (!isdrag || !ref?.current) return;
7114
- e.preventDefault();
7115
7359
  let dom = ref.current.getBoundingClientRect();
7116
7360
  let arr = cloneDeep(width);
7117
7361
  let data = arr.reduce((x, y, i) => {
@@ -7123,10 +7367,46 @@ function Columns(props) {
7123
7367
  arr[select_col] = e.nativeEvent.clientX - dom.left - data;
7124
7368
  setWidth(arr);
7125
7369
  }
7126
- function renderList(list, level) {
7370
+ function setlevel(data, level) {
7371
+ let arr = cloneDeep(store.expandkey);
7372
+ arr.fill('', level + 1);
7373
+ arr.splice(level, 1, data);
7374
+ return arr;
7375
+ }
7376
+ function setData(key, _data) {
7377
+ const fixdata = (data, level) => {
7378
+ let arr = data;
7379
+ let i = 0;
7380
+ while (i < arr?.length) {
7381
+ let item = arr[i];
7382
+ if (item.key == key) {
7383
+ item['children'] = _data;
7384
+ }
7385
+ if (Array.isArray(item.children) && item.children.length > 0) {
7386
+ fixdata(item.children);
7387
+ }
7388
+ i++;
7389
+ }
7390
+ return arr;
7391
+ };
7392
+ let arr = fixdata(data);
7393
+ onChange(arr);
7394
+ }
7395
+ if (!data.length) {
7396
+ return jsx("div", {
7397
+ className: 'explorer-columns notdata',
7398
+ children: jsx(NotData, {})
7399
+ });
7400
+ }
7401
+ function renderList(list, level, parent) {
7127
7402
  if (!list) {
7128
7403
  return jsx("div", {
7129
- className: cx$1('layer empty'),
7404
+ className: cx$1('layer empty', {
7405
+ select_col: select_col == level
7406
+ }),
7407
+ onClick: e => {
7408
+ setSelectCol(level);
7409
+ },
7130
7410
  children: jsxs("div", {
7131
7411
  className: 'empty-is-null',
7132
7412
  children: [jsx("div", {
@@ -7151,7 +7431,7 @@ function Columns(props) {
7151
7431
  className: cx$1('layer list', {
7152
7432
  select_col: select_col == level
7153
7433
  }),
7154
- onClick: () => {
7434
+ onClick: e => {
7155
7435
  setSelectCol(level);
7156
7436
  },
7157
7437
  style: {
@@ -7169,42 +7449,34 @@ function Columns(props) {
7169
7449
  ...v,
7170
7450
  key: level + '-' + i,
7171
7451
  icon: icons,
7172
- acitve: select_file[level] == v.key || select_info == v.key,
7452
+ acitve: store.expandkey[level] == v.key || select_info == v.key,
7173
7453
  id: v.key,
7174
7454
  end: end,
7175
7455
  checks: checks?.includes(v.key),
7176
- isedit: edit == v.key || v.create_file,
7177
- onEdit: () => {
7178
- setEdit(v.key);
7179
- },
7180
- onBlur: e => {
7181
- onRename?.(v.key, e.target.value, v);
7182
- setEdit('');
7456
+ isedit: store.reamekey == v.key || v.create_file,
7457
+ store: store,
7458
+ openMenu: store.openMenu,
7459
+ onRename: async (key, value, info) => {
7460
+ await props?.onRename?.(key, value, info);
7183
7461
  },
7462
+ onMenuClick: props?.onMenuClick,
7184
7463
  onClick: async () => {
7464
+ //shift 键按下 进行展开
7465
+ if (store.shift) return;
7185
7466
  setSelectInfo(v.key);
7186
7467
  if (v.type == 'folder') {
7187
- let select = select_file.map((id, i) => {
7188
- if (i > level) {
7189
- return '';
7190
- }
7191
- if (i == level) {
7192
- return v.key;
7193
- }
7194
- return id;
7195
- });
7196
- setSelectFile(select);
7468
+ let select = setlevel(v.key, level);
7197
7469
  let loaddata = null;
7198
- if (v.api && onLoadData) {
7199
- let data = await onLoadData?.(v.key);
7200
- if (Array.isArray(data)) {
7201
- loaddata = data;
7202
- }
7470
+ let data = await onLoadData?.(v.key);
7471
+ if (Array.isArray(data) && data.length) {
7472
+ loaddata = data;
7203
7473
  }
7204
- let arr = v?.children ? [...v?.children, ...(loaddata || [])] : loaddata;
7205
- setlevel(arr, level + 1);
7474
+ let arr = Array.isArray(v?.children) && v?.children.length ? [...v?.children] : loaddata;
7475
+ setData(v.key, arr);
7476
+ store.setExpandkey(select);
7206
7477
  }
7207
- }
7478
+ },
7479
+ parent: parent
7208
7480
  });
7209
7481
  }
7210
7482
  })
@@ -7218,22 +7490,6 @@ function Columns(props) {
7218
7490
  })]
7219
7491
  });
7220
7492
  }
7221
- function setlevel(data, level) {
7222
- let arr = cloneDeep(layer);
7223
- arr = arr.map((v, i) => {
7224
- if (i > level) {
7225
- return [];
7226
- }
7227
- if (i == level) {
7228
- return data;
7229
- }
7230
- return v;
7231
- });
7232
- setLayer(arr);
7233
- }
7234
- if (!data.length) {
7235
- return jsx(NotData, {});
7236
- }
7237
7493
  return jsx("div", {
7238
7494
  ref: ref,
7239
7495
  className: cx$1('explorer-columns', {
@@ -7243,12 +7499,28 @@ function Columns(props) {
7243
7499
  onMouseUp: () => {
7244
7500
  setIsdarg(false);
7245
7501
  },
7246
- onMouseDown: e => {
7502
+ onMouseDown: e => {},
7503
+ onContextMenu: e => {
7247
7504
  e.preventDefault();
7248
7505
  },
7249
7506
  children: layer.map((v, i) => {
7507
+ let parent = null;
7508
+ if (!i) {
7509
+ parent = store.curInfo;
7510
+ } else {
7511
+ let index = i - 1;
7512
+ let arr = layer[index];
7513
+ let key = store.expandkey[index];
7514
+ if (Array.isArray(arr) && key) {
7515
+ arr.map(v => {
7516
+ if (v.key == key) {
7517
+ parent = v;
7518
+ }
7519
+ });
7520
+ }
7521
+ }
7250
7522
  return jsx(React__default.Fragment, {
7251
- children: renderList(v, i)
7523
+ children: renderList(v, i, parent)
7252
7524
  }, i);
7253
7525
  })
7254
7526
  });
@@ -7346,7 +7618,9 @@ const Layout$1 = props => {
7346
7618
  className: 'file-continer-main',
7347
7619
  onClick: () => {
7348
7620
  store.setCurSelect(null);
7349
- store.setCurSelectFile(null);
7621
+ if (store?.menutype !== 'column') {
7622
+ store.setCurSelectFile(null);
7623
+ }
7350
7624
  },
7351
7625
  children: [store?.loading == ApiStatusEnum.LOADING && jsx(Loading, {}), jsxs(SelectBox, {
7352
7626
  getContainer: '.explorer-container',
@@ -7364,23 +7638,17 @@ const Layout$1 = props => {
7364
7638
  action: template?.[store.menutype]?.action,
7365
7639
  regionClass: template?.[store.menutype]?.regionClass,
7366
7640
  onChange: v => {
7367
- let map = store.dataMap || {};
7368
- let param = [];
7369
- v.forEach(checkedKeys => {
7370
- if (map[checkedKeys]) {
7371
- param.push(map[checkedKeys]);
7372
- }
7373
- });
7374
- onCheck?.(v, param);
7641
+ onCheck?.(v);
7375
7642
  },
7376
7643
  onUpload: props.onUpload,
7377
7644
  onDrag: () => {},
7378
7645
  onEndDrag: () => {},
7379
7646
  onStartDrag: () => {},
7380
7647
  loadMenu: loadMenu,
7381
- loadData: loadData,
7648
+ loadData: loadNode,
7382
7649
  onMenuClick: onMenuClick,
7383
7650
  children: [store?.menutype == 'column' && jsx(Columns, {
7651
+ store: store,
7384
7652
  icons: store.getIcons,
7385
7653
  data: store.curlist,
7386
7654
  checks: checks,
@@ -7390,7 +7658,10 @@ const Layout$1 = props => {
7390
7658
  onMenuClick: onMenuClick,
7391
7659
  onDblclick: onDblclick,
7392
7660
  height: height,
7393
- width: width
7661
+ width: width,
7662
+ onChange: v => {
7663
+ store.setCurList(v);
7664
+ }
7394
7665
  }), store?.menutype == 'table' && jsx(Tree, {
7395
7666
  type: 'table',
7396
7667
  checks: checks,
@@ -7405,6 +7676,7 @@ const Layout$1 = props => {
7405
7676
  isDelect: store.isDelect,
7406
7677
  isDownload: store.isDownload,
7407
7678
  isUpload: store.isDownload,
7679
+ selectedSuffix: store.selectedSuffix,
7408
7680
  height: height - 24,
7409
7681
  width: width,
7410
7682
  animation: false,
@@ -7416,14 +7688,7 @@ const Layout$1 = props => {
7416
7688
  isload: true,
7417
7689
  ischeck: truncate,
7418
7690
  onChecks: arr => {
7419
- let map = store.dataMap || {};
7420
- let param = [];
7421
- arr.forEach(checkedKeys => {
7422
- if (map[checkedKeys]) {
7423
- param.push(map[checkedKeys]);
7424
- }
7425
- });
7426
- onCheck?.(arr, param);
7691
+ onCheck?.(arr);
7427
7692
  },
7428
7693
  onSelect: v => {
7429
7694
  if (v?.type == 'folder' && v.expanded) {
@@ -7830,6 +8095,9 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
7830
8095
  isDownload = true,
7831
8096
  isNavtab = true,
7832
8097
  checks,
8098
+ accept,
8099
+ selectedSuffix,
8100
+ multiple = true,
7833
8101
  createFile,
7834
8102
  onCopy,
7835
8103
  onShear,
@@ -7860,6 +8128,8 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
7860
8128
  const [menutype, setMenutype] = useState('tile');
7861
8129
  const [infoshow, setInfoShow] = useState(false);
7862
8130
  const [loading, setLoading] = useState(ApiStatusEnum.READY);
8131
+ const [shift, setShift] = useState(false);
8132
+ const [control, setControl] = useState(false);
7863
8133
  const box = useRef(null);
7864
8134
  const boxMenu = useRef(null);
7865
8135
  const menu = useRef(null);
@@ -7897,8 +8167,10 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
7897
8167
  }, []);
7898
8168
  useLayoutEffect$1(() => {
7899
8169
  window.addEventListener('keydown', handleKeyDown);
8170
+ window.addEventListener('keyup', handleKeyUp);
7900
8171
  return () => {
7901
8172
  window.removeEventListener('keydown', handleKeyDown);
8173
+ window.removeEventListener('keyup', handleKeyUp);
7902
8174
  };
7903
8175
  }, [curSelect, dataMap, isDelect, isEdit, reamekey]);
7904
8176
  const handleKeyDown = e => {
@@ -7932,7 +8204,21 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
7932
8204
  curInfo && onPaste?.(curInfo);
7933
8205
  curInfo && reloadNode(curInfo.key);
7934
8206
  }
8207
+ if (e.key == 'Shift') {
8208
+ setShift(true);
8209
+ }
8210
+ if (e.key == 'Meta') {
8211
+ setControl(true);
8212
+ }
7935
8213
  };
8214
+ function handleKeyUp(e) {
8215
+ if (e.key == 'Shift') {
8216
+ setShift(false);
8217
+ }
8218
+ if (e.key == 'Meta') {
8219
+ setControl(false);
8220
+ }
8221
+ }
7936
8222
  const closeMenu = () => {
7937
8223
  boxMenu.current?.remove?.();
7938
8224
  boxMenu.current = null;
@@ -7946,21 +8232,25 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
7946
8232
  }
7947
8233
  }, [data, isNavtab]);
7948
8234
  useEffect(() => {
7949
- const addLevel = (data, map) => {
8235
+ let index = 0;
8236
+ const addLevel = (data, map, level) => {
7950
8237
  let i = 0;
7951
8238
  while (i < data.length) {
8239
+ let _level = level ? level + '-' + i : i + '';
7952
8240
  let item = data[i];
8241
+ item['index'] = index++;
8242
+ item['level'] = _level;
7953
8243
  map[item.key] = item;
7954
8244
  if (Array.isArray(item.children) && item.children.length > 0) {
7955
- addLevel(item.children, map);
8245
+ addLevel(item.children, map, _level);
7956
8246
  }
7957
8247
  i++;
7958
8248
  }
7959
8249
  return map;
7960
8250
  };
7961
- let map = addLevel(curlist, {});
8251
+ let map = addLevel(curlist, {}, '');
7962
8252
  setDataMap(map);
7963
- }, [curlist]);
8253
+ }, [curlist, curSelectFile]);
7964
8254
  useEffect(() => {
7965
8255
  setExpandkey([]);
7966
8256
  setCurSelect(null);
@@ -7993,7 +8283,7 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
7993
8283
  setCurInfo(data?.current || {});
7994
8284
  setTimeout(() => {
7995
8285
  closeload && setLoading(ApiStatusEnum.READY);
7996
- }, 300);
8286
+ }, 200);
7997
8287
  return data.fileList || [];
7998
8288
  }
7999
8289
  async function loadNode(key) {
@@ -8075,57 +8365,6 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
8075
8365
  return newData;
8076
8366
  }
8077
8367
  /* ************ 功能方法 **************** */
8078
- //创建和重名
8079
- async function onRename(key, value, info, type) {
8080
- if (info.create_file) {
8081
- const delata = data => {
8082
- let arr = data;
8083
- let filter = [];
8084
- let i = 0;
8085
- while (i < arr.length) {
8086
- let item = arr[i];
8087
- if (!item?.create_file) {
8088
- filter.push(item);
8089
- }
8090
- if (Array.isArray(item.children)) {
8091
- item.children = delata(item.children);
8092
- }
8093
- i++;
8094
- }
8095
- return filter || [];
8096
- };
8097
- if (value === false) {
8098
- let arr = delata(curlist);
8099
- setCurList(arr);
8100
- return;
8101
- }
8102
- if (curInfo) {
8103
- await createFile?.(value, curInfo);
8104
- curInfo?.key && loadData(curInfo?.key);
8105
- reloadNode(curInfo?.key);
8106
- }
8107
- } else {
8108
- let data = await _onRename?.(key, value, info);
8109
- if (info.type == 'folder' || type == 'menu') {
8110
- if (data?.key) {
8111
- if (key === curInfo?.key) {
8112
- loadData(data.key);
8113
- } else {
8114
- curInfo?.key && loadData(curInfo?.key);
8115
- }
8116
- updata(key, {
8117
- key: data.key,
8118
- title: value
8119
- });
8120
- }
8121
- } else {
8122
- curInfo?.key && loadData(curInfo?.key);
8123
- updata(key, {
8124
- title: value
8125
- });
8126
- }
8127
- }
8128
- }
8129
8368
  async function uploadFile() {
8130
8369
  if (!curInfo) return;
8131
8370
  let input = document.createElement('input');
@@ -8144,6 +8383,7 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
8144
8383
  loadData?.(curInfo?.key);
8145
8384
  };
8146
8385
  }
8386
+ //新建文件夹
8147
8387
  function createFolder() {
8148
8388
  const folderName = (folders, folderName) => {
8149
8389
  let newName = folderName.trim();
@@ -8164,10 +8404,16 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
8164
8404
  let item = arr[i];
8165
8405
  if (item.key == key) {
8166
8406
  if (Array.isArray(item.children)) {
8407
+ let titles = [];
8167
8408
  item.children.forEach(v => {
8409
+ if (v.title) {
8410
+ titles.push(v.title);
8411
+ }
8168
8412
  if (v.type == 'folder') folder.push(v);
8169
8413
  if (v.type == 'file') file.push(v);
8170
8414
  });
8415
+ let _data = folderName(titles, '新建文件夹');
8416
+ child['title'] = _data;
8171
8417
  folder.push(child);
8172
8418
  item.children = [...folder, ...file];
8173
8419
  } else {
@@ -8196,66 +8442,14 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
8196
8442
  return arr || [];
8197
8443
  };
8198
8444
  let arr = cloneDeep(curlist) || [];
8199
- let title = arr.map(v => {
8200
- return v.title;
8201
- });
8202
- let data = folderName(title, '新建文件夹');
8203
8445
  let list = addData(arr, curSelectFile || '', {
8204
8446
  key: getKey$1(),
8205
8447
  type: 'folder',
8206
- title: data,
8448
+ title: '新建文件夹',
8207
8449
  create_file: true
8208
8450
  });
8209
8451
  setCurList(list);
8210
8452
  }
8211
- async function onMenuClick(key, param, type) {
8212
- if (key == 'remove') {
8213
- if (type == 'menu') {
8214
- await onDelect?.([param.key], param);
8215
- } else {
8216
- await onDelect?.(checks || [], param);
8217
- }
8218
- if (param.key == curInfo?.key) {
8219
- data?.[0]?.key && loadData(data?.[0]?.key);
8220
- } else {
8221
- curInfo?.key && loadData(curInfo?.key);
8222
- }
8223
- if (param.type == 'folder') {
8224
- reloadNode(param.parentPath);
8225
- }
8226
- return;
8227
- }
8228
- if (key == 'copy') {
8229
- onCopy?.(param);
8230
- return;
8231
- }
8232
- if (key == 'shear') {
8233
- onShear?.(param);
8234
- return;
8235
- }
8236
- if (key == 'paste') {
8237
- onPaste?.(param);
8238
- curInfo?.key && loadData(curInfo.key);
8239
- reloadNode(param.key);
8240
- return;
8241
- }
8242
- if (key == 'info') {
8243
- openFile({
8244
- className: 'explorer-details-modal',
8245
- modalWidth: 450,
8246
- modalHeight: 620,
8247
- content: jsx(DetailsInfo, {
8248
- info: param,
8249
- getIcons: Icons,
8250
- renderFileInfo: props?.renderFileInfo
8251
- })
8252
- });
8253
- }
8254
- _onMenuClick?.(key, {
8255
- ...param,
8256
- isEdit: isEdit
8257
- });
8258
- }
8259
8453
  function openMenu(props, param) {
8260
8454
  closeMenu();
8261
8455
  let {
@@ -8311,6 +8505,126 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
8311
8505
  `;
8312
8506
  }, 100);
8313
8507
  }
8508
+ /* *********** 拦截进行特殊处理 *********** */
8509
+ async function onMenuClick(key, param, type) {
8510
+ if (key == 'remove') {
8511
+ if (type == 'menu') {
8512
+ await onDelect?.([param.key], param);
8513
+ } else {
8514
+ await onDelect?.(checks || [], param);
8515
+ }
8516
+ if (param.key == curInfo?.key) {
8517
+ data?.[0]?.key && loadData(data?.[0]?.key);
8518
+ } else {
8519
+ curInfo?.key && loadData(curInfo?.key);
8520
+ }
8521
+ if (param.type == 'folder') {
8522
+ reloadNode(param.parentPath);
8523
+ }
8524
+ return;
8525
+ }
8526
+ if (key == 'copy') {
8527
+ onCopy?.(param);
8528
+ return;
8529
+ }
8530
+ if (key == 'shear') {
8531
+ onShear?.(param);
8532
+ return;
8533
+ }
8534
+ if (key == 'paste') {
8535
+ onPaste?.(param);
8536
+ curInfo?.key && loadData(curInfo.key);
8537
+ reloadNode(param.key);
8538
+ return;
8539
+ }
8540
+ if (key == 'info') {
8541
+ openFile({
8542
+ className: 'explorer-details-modal',
8543
+ modalWidth: 450,
8544
+ modalHeight: 620,
8545
+ content: jsx(DetailsInfo, {
8546
+ info: param,
8547
+ getIcons: Icons,
8548
+ renderFileInfo: props?.renderFileInfo
8549
+ })
8550
+ });
8551
+ }
8552
+ _onMenuClick?.(key, {
8553
+ ...param,
8554
+ isEdit: isEdit
8555
+ });
8556
+ }
8557
+ //创建和重名
8558
+ async function onRename(key, value, info, type) {
8559
+ if (info.create_file) {
8560
+ const delata = data => {
8561
+ let arr = data;
8562
+ let filter = [];
8563
+ let i = 0;
8564
+ while (i < arr.length) {
8565
+ let item = arr[i];
8566
+ if (!item?.create_file) {
8567
+ filter.push(item);
8568
+ }
8569
+ if (Array.isArray(item.children)) {
8570
+ item.children = delata(item.children);
8571
+ }
8572
+ i++;
8573
+ }
8574
+ return filter || [];
8575
+ };
8576
+ //取消创建
8577
+ if (value === false) {
8578
+ let arr = delata(curlist);
8579
+ setCurList(arr);
8580
+ return;
8581
+ }
8582
+ let param = curInfo;
8583
+ if (curSelectFile && dataMap?.[curSelectFile]) {
8584
+ param = dataMap?.[curSelectFile];
8585
+ }
8586
+ if (curInfo) {
8587
+ setLoading(ApiStatusEnum.LOADING);
8588
+ await createFile?.(value, param);
8589
+ loadData(curInfo.key, null, false);
8590
+ reloadNode(curInfo?.key);
8591
+ setLoading(ApiStatusEnum.READY);
8592
+ }
8593
+ } else {
8594
+ let data = await _onRename?.(key, value, info);
8595
+ if (info.type == 'folder' || type == 'menu') {
8596
+ if (data?.key) {
8597
+ if (key === curInfo?.key) {
8598
+ loadData(data.key);
8599
+ } else {
8600
+ curInfo?.key && loadData(curInfo?.key);
8601
+ }
8602
+ updata(key, {
8603
+ key: data.key,
8604
+ title: value
8605
+ });
8606
+ }
8607
+ } else {
8608
+ curInfo?.key && loadData(curInfo?.key);
8609
+ updata(key, {
8610
+ title: value
8611
+ });
8612
+ }
8613
+ }
8614
+ }
8615
+ async function onCheck(arr) {
8616
+ let map = dataMap || {};
8617
+ let param = [];
8618
+ if (!multiple) {
8619
+ arr = [arr[0]];
8620
+ }
8621
+ arr.forEach(checkedKeys => {
8622
+ if (map[checkedKeys]) {
8623
+ param.push(map[checkedKeys]);
8624
+ }
8625
+ });
8626
+ props.onCheck?.(arr, param);
8627
+ }
8314
8628
  return jsx(ExampleContext.Provider, {
8315
8629
  value: {
8316
8630
  //data
@@ -8324,6 +8638,10 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
8324
8638
  isUpload: isUpload,
8325
8639
  isEdit: isEdit,
8326
8640
  isDownload: isDownload,
8641
+ selectedSuffix: selectedSuffix,
8642
+ multiple: multiple,
8643
+ shift,
8644
+ control,
8327
8645
  menutype,
8328
8646
  pathDisplay,
8329
8647
  columns: columns || defaultColumns,
@@ -8373,6 +8691,7 @@ const Explorer = /*#__PURE__*/forwardRef((props, ref) => {
8373
8691
  loadData: loadData,
8374
8692
  loadNode: loadNode,
8375
8693
  onRename: onRename,
8694
+ onCheck: onCheck,
8376
8695
  onMenuClick: onMenuClick
8377
8696
  })
8378
8697
  })