flexlayout-react 0.8.10 → 0.8.11
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/ChangeLog.txt +7 -0
- package/README.md +28 -20
- package/declarations/view/BorderTab.d.ts +1 -2
- package/declarations/view/Icons.d.ts +7 -8
- package/declarations/view/Layout.d.ts +1 -1
- package/declarations/view/SizeTracker.d.ts +1 -1
- package/dist/flexlayout.js +49 -29
- package/dist/flexlayout_min.js +1 -1
- package/dist/flexlayout_min.js.LICENSE.txt +10 -0
- package/dist/src/Attribute.js +43 -0
- package/dist/src/Attribute.js.map +1 -0
- package/dist/src/AttributeDefinitions.js +132 -0
- package/dist/src/AttributeDefinitions.js.map +1 -0
- package/dist/src/DockLocation.js +121 -0
- package/dist/src/DockLocation.js.map +1 -0
- package/dist/src/DropInfo.js +10 -0
- package/dist/src/DropInfo.js.map +1 -0
- package/dist/src/I18nLabel.js +14 -0
- package/dist/src/I18nLabel.js.map +1 -0
- package/dist/src/Orientation.js +23 -0
- package/dist/src/Orientation.js.map +1 -0
- package/dist/src/Rect.js +111 -0
- package/dist/src/Rect.js.map +1 -0
- package/dist/src/Types.js +95 -0
- package/dist/src/Types.js.map +1 -0
- package/dist/src/index.js +22 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/model/Action.js +7 -0
- package/dist/src/model/Action.js.map +1 -0
- package/dist/src/model/Actions.js +170 -0
- package/dist/src/model/Actions.js.map +1 -0
- package/dist/src/model/BorderNode.js +390 -0
- package/dist/src/model/BorderNode.js.map +1 -0
- package/dist/src/model/BorderSet.js +67 -0
- package/dist/src/model/BorderSet.js.map +1 -0
- package/dist/src/model/ICloseType.js +7 -0
- package/dist/src/model/ICloseType.js.map +1 -0
- package/dist/src/model/IDraggable.js +2 -0
- package/dist/src/model/IDraggable.js.map +1 -0
- package/dist/src/model/IDropTarget.js +2 -0
- package/dist/src/model/IDropTarget.js.map +1 -0
- package/dist/src/model/IJsonModel.js +2 -0
- package/dist/src/model/IJsonModel.js.map +1 -0
- package/dist/src/model/LayoutWindow.js +81 -0
- package/dist/src/model/LayoutWindow.js.map +1 -0
- package/dist/src/model/Model.js +608 -0
- package/dist/src/model/Model.js.map +1 -0
- package/dist/src/model/Node.js +218 -0
- package/dist/src/model/Node.js.map +1 -0
- package/dist/src/model/RowNode.js +492 -0
- package/dist/src/model/RowNode.js.map +1 -0
- package/dist/src/model/TabNode.js +293 -0
- package/dist/src/model/TabNode.js.map +1 -0
- package/dist/src/model/TabSetNode.js +469 -0
- package/dist/src/model/TabSetNode.js.map +1 -0
- package/dist/src/model/Utils.js +48 -0
- package/dist/src/model/Utils.js.map +1 -0
- package/dist/src/view/BorderButton.js +126 -0
- package/dist/src/view/BorderButton.js.map +1 -0
- package/dist/src/view/BorderTab.js +44 -0
- package/dist/src/view/BorderTab.js.map +1 -0
- package/dist/src/view/BorderTabSet.js +138 -0
- package/dist/src/view/BorderTabSet.js.map +1 -0
- package/dist/src/view/DragContainer.js +16 -0
- package/dist/src/view/DragContainer.js.map +1 -0
- package/dist/src/view/ErrorBoundary.js +24 -0
- package/dist/src/view/ErrorBoundary.js.map +1 -0
- package/dist/src/view/Icons.js +29 -0
- package/dist/src/view/Icons.js.map +1 -0
- package/dist/src/view/Layout.js +881 -0
- package/dist/src/view/Layout.js.map +1 -0
- package/dist/src/view/Overlay.js +9 -0
- package/dist/src/view/Overlay.js.map +1 -0
- package/dist/src/view/PopoutWindow.js +129 -0
- package/dist/src/view/PopoutWindow.js.map +1 -0
- package/dist/src/view/PopupMenu.js +89 -0
- package/dist/src/view/PopupMenu.js.map +1 -0
- package/dist/src/view/Row.js +46 -0
- package/dist/src/view/Row.js.map +1 -0
- package/dist/src/view/SizeTracker.js +12 -0
- package/dist/src/view/SizeTracker.js.map +1 -0
- package/dist/src/view/Splitter.js +192 -0
- package/dist/src/view/Splitter.js.map +1 -0
- package/dist/src/view/Tab.js +91 -0
- package/dist/src/view/Tab.js.map +1 -0
- package/dist/src/view/TabButton.js +124 -0
- package/dist/src/view/TabButton.js.map +1 -0
- package/dist/src/view/TabButtonStamp.js +15 -0
- package/dist/src/view/TabButtonStamp.js.map +1 -0
- package/dist/src/view/TabOverflowHook.js +266 -0
- package/dist/src/view/TabOverflowHook.js.map +1 -0
- package/dist/src/view/TabSet.js +256 -0
- package/dist/src/view/TabSet.js.map +1 -0
- package/dist/src/view/Utils.js +110 -0
- package/dist/src/view/Utils.js.map +1 -0
- package/lib/view/BorderButton.js +6 -8
- package/lib/view/BorderButton.js.map +1 -1
- package/lib/view/BorderTab.js +18 -9
- package/lib/view/BorderTab.js.map +1 -1
- package/lib/view/BorderTabSet.js +11 -17
- package/lib/view/BorderTabSet.js.map +1 -1
- package/lib/view/DragContainer.js +2 -2
- package/lib/view/DragContainer.js.map +1 -1
- package/lib/view/ErrorBoundary.js +2 -2
- package/lib/view/ErrorBoundary.js.map +1 -1
- package/lib/view/Icons.js +8 -20
- package/lib/view/Icons.js.map +1 -1
- package/lib/view/Layout.js +36 -79
- package/lib/view/Layout.js.map +1 -1
- package/lib/view/Overlay.js +2 -2
- package/lib/view/Overlay.js.map +1 -1
- package/lib/view/PopupMenu.js +4 -5
- package/lib/view/PopupMenu.js.map +1 -1
- package/lib/view/Row.js +5 -4
- package/lib/view/Row.js.map +1 -1
- package/lib/view/SizeTracker.js +2 -1
- package/lib/view/SizeTracker.js.map +1 -1
- package/lib/view/Splitter.js +9 -4
- package/lib/view/Splitter.js.map +1 -1
- package/lib/view/Tab.js +3 -4
- package/lib/view/Tab.js.map +1 -1
- package/lib/view/TabButton.js +6 -8
- package/lib/view/TabButton.js.map +1 -1
- package/lib/view/TabButtonStamp.js +4 -6
- package/lib/view/TabButtonStamp.js.map +1 -1
- package/lib/view/TabSet.js +38 -42
- package/lib/view/TabSet.js.map +1 -1
- package/lib/view/Utils.js +3 -3
- package/lib/view/Utils.js.map +1 -1
- package/package.json +87 -82
- package/playwright-report/data/01f8ff379b7b7c06b0f8dbd65cbd55e95f8ca470.zip +0 -0
- package/playwright-report/data/02a706b995d751dee8ac0429e29eafb796a23f96.zip +0 -0
- package/playwright-report/data/04468c5a7304bad1acbe32d3376bfc5038e172d9.zip +0 -0
- package/playwright-report/data/04ffe14721deea0c6402bb96c78055475f6cd687.zip +0 -0
- package/playwright-report/data/07e1bb8bd6407ceafa7a1051839d398f34b41a52.zip +0 -0
- package/playwright-report/data/0d17b99e2ddd975da4868f295b370a9fc9b55993.zip +0 -0
- package/playwright-report/data/108805618d29c7800d55d7dd8da36829fec366bd.zip +0 -0
- package/playwright-report/data/1271fd2bc76809c25b62351f4321b396e745a199.zip +0 -0
- package/playwright-report/data/16bd316f5e3e9ad6c9dc2a6a0388f3425c1a61d9.zip +0 -0
- package/playwright-report/data/1a1b06cebe59d981e21198164093230b0a1704fd.zip +0 -0
- package/playwright-report/data/1b3b6bba4aca415bc586b2a0abb18410af26fbf1.zip +0 -0
- package/playwright-report/data/1ce927369a55edf14ec99e0029d1a342cb0fcfa4.zip +0 -0
- package/playwright-report/data/20a694648a90f0a805a4397b73699142e5dd50c1.zip +0 -0
- package/playwright-report/data/211f1c8fc3f5d052d935906201f29a1e42a2fbd8.zip +0 -0
- package/playwright-report/data/2176124681e769fbba593a272e67331fd69e56ef.zip +0 -0
- package/playwright-report/data/2487db6273b09acd9a62a9ecfa8f1e411cc769df.zip +0 -0
- package/playwright-report/data/25abefed6606e15cac6dc83e3ea4e85896233020.zip +0 -0
- package/playwright-report/data/2752051b8593d432be1a623813f2dbee043dc959.zip +0 -0
- package/playwright-report/data/2d72001a7f57a11282fe741ca22501b34f7576a2.zip +0 -0
- package/playwright-report/data/308de4d252afe1db5aeda783ea3eaf09368aa812.zip +0 -0
- package/playwright-report/data/30f265807a34ee9bb2ddd931970be6f572a42ffe.zip +0 -0
- package/playwright-report/data/326599ace543d3340403f5eaa0f28ef73f7d3cfc.zip +0 -0
- package/playwright-report/data/3662fcf1839c6bb164e1aceea5e25b410bae6286.zip +0 -0
- package/playwright-report/data/38cdebbb090386af04f96f13bf45b2a23feb6cf5.zip +0 -0
- package/playwright-report/data/3b45c7876ca7a4208061f69fa0cce9f9e619557c.zip +0 -0
- package/playwright-report/data/3c6115f8ff03527f3b888e8c6626d086146bb961.zip +0 -0
- package/playwright-report/data/3e976a69f9bc188048c96969507a28fc5411da40.zip +0 -0
- package/playwright-report/data/420bd6c0ed97c53e6ee5108c11c337690ed9dd71.zip +0 -0
- package/playwright-report/data/424c925f1d020f7918c5b1d4e93a3aff4ffd0d35.zip +0 -0
- package/playwright-report/data/4459657c233583f0bb5f541ba2a56d14fc04324f.zip +0 -0
- package/playwright-report/data/45dbca16424f69b6af3f201fd918186e66e6a921.zip +0 -0
- package/playwright-report/data/4c7242437d15e34066b69d5f3a71e21f436d81bb.zip +0 -0
- package/playwright-report/data/56f84e2288e6485b68f0f78f79af97016d066eea.zip +0 -0
- package/playwright-report/data/679d4cfcb398dd2d19703be59bbf1de72f73fa3e.zip +0 -0
- package/playwright-report/data/686279f3ccdca1213fe91a9901f1ca469a41db4b.zip +0 -0
- package/playwright-report/data/69403980b98daeb052c732f3d984b7ccc51022aa.zip +0 -0
- package/playwright-report/data/6d91e10cd5dc95944881ea0f875bf0e531c63164.zip +0 -0
- package/playwright-report/data/6f362695f59905c3acdcafb6eeacfa4b068bc030.zip +0 -0
- package/playwright-report/data/71dd5897288168b0f7fb2e187f2b543e880733b1.zip +0 -0
- package/playwright-report/data/7540a41a9c123cffc1750447ccb69d9fb8cc8ba5.zip +0 -0
- package/playwright-report/data/78f8483a26c47ca761f43b1f142a9fb9d001b27e.zip +0 -0
- package/playwright-report/data/7e8bd5ba547094dcf303d450853b2f74f41749b2.zip +0 -0
- package/playwright-report/data/7fbec8e63ea2ee1702a94fe4d837067192e661f0.zip +0 -0
- package/playwright-report/data/87f2ea42a46cbd21813358d7d6e31d9999fca953.zip +0 -0
- package/playwright-report/data/8db527a1f9b753036cf63bb4afc96a765007fe82.zip +0 -0
- package/playwright-report/data/8e5ccd4bd56f3843f4e788c5e9842165221c2748.zip +0 -0
- package/playwright-report/data/8fc12e2795e02ee2ad773ec7be25f94b6ca697ed.zip +0 -0
- package/playwright-report/data/9d10ab1649ded4751d19014847e110b0b03ad126.zip +0 -0
- package/playwright-report/data/ab82c3994c6614fa6873fc92fd44ca78cb45f9d6.zip +0 -0
- package/playwright-report/data/ac554655d509fe64199a053e715def4ce4bbd618.zip +0 -0
- package/playwright-report/data/ad8e5a0cec5ec3369478099a58b7652c0dd636f1.zip +0 -0
- package/playwright-report/data/ae30baf5dea2dc0dd2ca87ffa08afb936b27fef1.zip +0 -0
- package/playwright-report/data/bc7631ffd4df693573a3233ec403a1f9cbcb00a9.zip +0 -0
- package/playwright-report/data/bcfe71e7532702969ecdde584a294907ed21525e.zip +0 -0
- package/playwright-report/data/bf020e09e20d0cd6e1b8aa82153e84f9d40c7f74.zip +0 -0
- package/playwright-report/data/c3452f499f82ef644c3d314626d3d9c762ff5c20.zip +0 -0
- package/playwright-report/data/c5dfbb00ea0965a4214f02cde22245958bb31c86.zip +0 -0
- package/playwright-report/data/c716ede7c5174d8a83653a6862605eca04783bad.zip +0 -0
- package/playwright-report/data/c95ca5869740edf6d1d627d120aa9ba26b1d3415.zip +0 -0
- package/playwright-report/data/cc17390169d327b4dfc2a9b3a8279e74ff975b1d.zip +0 -0
- package/playwright-report/data/d0ff6b9f342d792119f1513cc53c9f315a56251b.zip +0 -0
- package/playwright-report/data/d26377153bff611b5ba5a1148fc8858f7bb2cb7b.zip +0 -0
- package/playwright-report/data/dc0608de1b624a691f2f393bf450fc01591076ef.zip +0 -0
- package/playwright-report/data/dee4c585c248f4827601afbde02d3732761bdd8b.zip +0 -0
- package/playwright-report/data/e4cdfceef70735028de78f94f7e07a1e65fa317d.zip +0 -0
- package/playwright-report/data/e64d89424643af3f746a091f7567db49b0b45f3c.zip +0 -0
- package/playwright-report/data/e70483c7d13bb871f5c5b4aa54149172d58bf0c0.zip +0 -0
- package/playwright-report/data/e8333b653df262d800ee7b5329503b975d420e87.zip +0 -0
- package/playwright-report/data/ed1bd19a957a6165ba73a644af4959590b23eed9.zip +0 -0
- package/playwright-report/data/f35cf046cdf897abd96f318f79443407e58b8f0b.zip +0 -0
- package/playwright-report/data/f8793a7c69b939ac07422cf41aac45ebe4a86908.zip +0 -0
- package/playwright-report/data/fb2a383b96839380e90e0137363a574e665aed38.zip +0 -0
- package/playwright-report/data/fede8e774c66e329bdac055d6d67e73aa75b14fc.zip +0 -0
- package/playwright-report/index.html +71 -0
- package/playwright-report/trace/assets/codeMirrorModule-DpJ-EmBQ.js +24 -0
- package/playwright-report/trace/assets/defaultSettingsView-DTenqiGw.js +259 -0
- package/playwright-report/trace/codeMirrorModule.C3UTv-Ge.css +1 -0
- package/playwright-report/trace/codicon.DCmgc-ay.ttf +0 -0
- package/playwright-report/trace/defaultSettingsView.5fN5lw10.css +1 -0
- package/playwright-report/trace/index.CFOW-Ezb.css +1 -0
- package/playwright-report/trace/index.CUq7VgrV.js +2 -0
- package/playwright-report/trace/index.html +43 -0
- package/playwright-report/trace/playwright-logo.svg +9 -0
- package/playwright-report/trace/snapshot.html +21 -0
- package/playwright-report/trace/sw.bundle.js +3 -0
- package/playwright-report/trace/uiMode.BatfzHMG.css +1 -0
- package/playwright-report/trace/uiMode.CHJSAD7F.js +5 -0
- package/playwright-report/trace/uiMode.html +17 -0
- package/playwright-report/trace/xtermModule.Beg8tuEN.css +32 -0
- package/playwright.config.ts +79 -0
- package/screenshots/PlaywrightUI.png +0 -0
- package/src/view/BorderTab.tsx +18 -7
- package/src/view/Icons.tsx +0 -2
- package/src/view/Layout.tsx +2 -2
- package/src/view/Overlay.tsx +0 -1
- package/src/view/Splitter.tsx +6 -0
- package/src/view/TabButtonStamp.tsx +0 -1
- package/src/view/TabSet.tsx +16 -7
- package/test-results/view-Add-methods-add-to-active-tabset-chromium/trace.zip +0 -0
- package/test-results/view-Add-methods-drag-to-border-chromium/trace.zip +0 -0
- package/test-results/view-Add-methods-drag-to-tabset-chromium/trace.zip +0 -0
- package/test-results/view-Delete-methods-delete-all-tabs-chromium/trace.zip +0 -0
- package/test-results/view-Delete-methods-delete-tab-chromium/trace.zip +0 -0
- package/test-results/view-Extended-App-onRenderTab-chromium/trace.zip +0 -0
- package/test-results/view-Extended-App-onRenderTab-in-border-chromium/trace.zip +0 -0
- package/test-results/view-Extended-App-onRenderTabSet-chromium/trace.zip +0 -0
- package/test-results/view-Extended-App-onRenderTabSet-for-border-chromium/trace.zip +0 -0
- package/test-results/view-Extended-App-onRenderTabSet-sticky-buttons-chromium/trace.zip +0 -0
- package/test-results/view-Extended-layout2-borders-autohide-left-chromium/trace.zip +0 -0
- package/test-results/view-Extended-layout2-borders-autohide-top-chromium/trace.zip +0 -0
- package/test-results/view-Extended-layout2-check-border-bottom-min-size-chromium/trace.zip +0 -0
- package/test-results/view-Extended-layout2-check-border-left-min-size-chromium/trace.zip +0 -0
- package/test-results/view-Extended-layout2-check-border-right-min-size-chromium/trace.zip +0 -0
- package/test-results/view-Extended-layout2-check-border-top-min-size-chromium/trace.zip +0 -0
- package/test-results/view-Extended-layout2-check-tabset-min-size-chromium/trace.zip +0 -0
- package/test-results/view-Extended-layout2-tabset-close-chromium/trace.zip +0 -0
- package/test-results/view-Maximize-methods-maximize-tabset-using-double-click-chromium/trace.zip +0 -0
- package/test-results/view-Maximize-methods-maximize-tabset-using-max-button-chromium/trace.zip +0 -0
- package/test-results/view-Others-click-on-tab-button-causes-tabset-activate-chromium/trace.zip +0 -0
- package/test-results/view-Others-click-on-tab-contents-causes-tabset-activate-chromium/trace.zip +0 -0
- package/test-results/view-Others-click-on-tabstrip-causes-tabset-activate-chromium/trace.zip +0 -0
- package/test-results/view-Others-rename-tab-cancelled-with-esc-chromium/trace.zip +0 -0
- package/test-results/view-Others-rename-tab-chromium/trace.zip +0 -0
- package/test-results/view-Overflow-menu-show-menu-chromium/trace.zip +0 -0
- package/test-results/view-Splitters-horizontal--5a358-ter-to-bottom-edge-and-back-chromium/trace.zip +0 -0
- package/test-results/view-Splitters-horizontal--f02d2-litter-to-top-edge-and-back-chromium/trace.zip +0 -0
- package/test-results/view-Splitters-horizontal-resizes-with-hsplitter-chromium/trace.zip +0 -0
- package/test-results/view-Splitters-vsplitter-chromium/trace.zip +0 -0
- package/test-results/view-Splitters-vsplitter-to-edge-chromium/trace.zip +0 -0
- package/test-results/view-Splitters-vsplitter-to-edge-left-chromium/trace.zip +0 -0
- package/test-results/view-borders-border-bottom-to-tab-chromium/trace.zip +0 -0
- package/test-results/view-borders-border-left-to-tab-chromium/trace.zip +0 -0
- package/test-results/view-borders-border-right-to-tab-chromium/trace.zip +0 -0
- package/test-results/view-borders-border-top-to-tab-chromium/trace.zip +0 -0
- package/test-results/view-borders-move-tab-in-border-bottom-chromium/trace.zip +0 -0
- package/test-results/view-borders-move-tab-in-border-left-chromium/trace.zip +0 -0
- package/test-results/view-borders-move-tab-in-border-right-chromium/trace.zip +0 -0
- package/test-results/view-borders-move-tab-in-border-top-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-border-bottom-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-border-left-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-border-right-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-border-top-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-open-border-bottom-center-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-open-border-bottom-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-open-border-left-center-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-open-border-left-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-open-border-right-center-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-open-border-right-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-open-border-top-center-chromium/trace.zip +0 -0
- package/test-results/view-borders-tab-to-open-border-top-chromium/trace.zip +0 -0
- package/test-results/view-drag-tests-two-tabs-tab-to-edge-chromium/trace.zip +0 -0
- package/test-results/view-drag-tests-two-tabs-tab-to-tab-bottom-chromium/trace.zip +0 -0
- package/test-results/view-drag-tests-two-tabs-tab-to-tab-center-chromium/trace.zip +0 -0
- package/test-results/view-drag-tests-two-tabs-tab-to-tab-left-chromium/trace.zip +0 -0
- package/test-results/view-drag-tests-two-tabs-tab-to-tab-right-chromium/trace.zip +0 -0
- package/test-results/view-drag-tests-two-tabs-tab-to-tab-top-chromium/trace.zip +0 -0
- package/test-results/view-tab-can-have-icon-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-move-tab-in-tabstrip-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-move-tabstrip-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-row-to-column-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-row-to-single-tabset-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-tab-to-edge-bottom-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-tab-to-edge-left-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-tab-to-edge-right-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-tab-to-edge-top-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-tab-to-tab-bottom-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-tab-to-tab-center-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-tab-to-tab-left-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-tab-to-tab-right-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-tab-to-tab-top-chromium/trace.zip +0 -0
- package/test-results/view-three-tabs-tab-to-tabset-chromium/trace.zip +0 -0
- package/tests-playwright/helpers.ts +124 -0
- package/tests-playwright/view.spec.ts +911 -0
- package/eslint.config.mjs +0 -19
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
import { TabSetNode } from "../model/TabSetNode";
|
|
4
|
+
import { CLASSES } from "../Types";
|
|
5
|
+
import { BorderNode } from "../model/BorderNode";
|
|
6
|
+
import { Actions } from "../model/Actions";
|
|
7
|
+
/** @internal */
|
|
8
|
+
export const Tab = (props) => {
|
|
9
|
+
const { layout, selected, node, path } = props;
|
|
10
|
+
const selfRef = React.useRef(null);
|
|
11
|
+
const firstSelect = React.useRef(true);
|
|
12
|
+
const parentNode = node.getParent();
|
|
13
|
+
const rect = parentNode.getContentRect();
|
|
14
|
+
React.useLayoutEffect(() => {
|
|
15
|
+
const element = node.getMoveableElement();
|
|
16
|
+
selfRef.current.appendChild(element);
|
|
17
|
+
node.setMoveableElement(element);
|
|
18
|
+
const handleScroll = () => {
|
|
19
|
+
node.saveScrollPosition();
|
|
20
|
+
};
|
|
21
|
+
// keep scroll position
|
|
22
|
+
element.addEventListener('scroll', handleScroll);
|
|
23
|
+
// listen for clicks to change active tabset
|
|
24
|
+
selfRef.current.addEventListener("pointerdown", onPointerDown);
|
|
25
|
+
return () => {
|
|
26
|
+
element.removeEventListener('scroll', handleScroll);
|
|
27
|
+
if (selfRef.current) {
|
|
28
|
+
selfRef.current.removeEventListener("pointerdown", onPointerDown);
|
|
29
|
+
}
|
|
30
|
+
node.setVisible(false);
|
|
31
|
+
};
|
|
32
|
+
}, []);
|
|
33
|
+
React.useEffect(() => {
|
|
34
|
+
if (node.isSelected()) {
|
|
35
|
+
if (firstSelect.current) {
|
|
36
|
+
node.restoreScrollPosition(); // if window docked back in
|
|
37
|
+
firstSelect.current = false;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
const onPointerDown = () => {
|
|
42
|
+
const parent = node.getParent(); // cannot use parentNode here since will be out of date
|
|
43
|
+
if (parent instanceof TabSetNode) {
|
|
44
|
+
if (!parent.isActive()) {
|
|
45
|
+
layout.doAction(Actions.setActiveTabset(parent.getId(), layout.getWindowId()));
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
node.setRect(rect); // needed for resize event
|
|
50
|
+
const cm = layout.getClassName;
|
|
51
|
+
const style = {};
|
|
52
|
+
rect.styleWithPosition(style);
|
|
53
|
+
let overlay = null;
|
|
54
|
+
if (selected) {
|
|
55
|
+
node.setVisible(true);
|
|
56
|
+
if (document.hidden && node.isEnablePopoutOverlay()) {
|
|
57
|
+
const overlayStyle = {};
|
|
58
|
+
rect.styleWithPosition(overlayStyle);
|
|
59
|
+
overlay = (_jsx("div", { style: overlayStyle, className: cm(CLASSES.FLEXLAYOUT__TAB_OVERLAY) }));
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
style.display = "none";
|
|
64
|
+
node.setVisible(false);
|
|
65
|
+
}
|
|
66
|
+
if (parentNode instanceof TabSetNode) {
|
|
67
|
+
if (node.getModel().getMaximizedTabset(layout.getWindowId()) !== undefined) {
|
|
68
|
+
if (parentNode.isMaximized()) {
|
|
69
|
+
style.zIndex = 10;
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
style.display = "none";
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
if (parentNode instanceof BorderNode) {
|
|
77
|
+
if (!parentNode.isShowing()) {
|
|
78
|
+
style.display = "none";
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
let className = cm(CLASSES.FLEXLAYOUT__TAB);
|
|
82
|
+
if (parentNode instanceof BorderNode) {
|
|
83
|
+
className += " " + cm(CLASSES.FLEXLAYOUT__TAB_BORDER);
|
|
84
|
+
className += " " + cm(CLASSES.FLEXLAYOUT__TAB_BORDER_ + parentNode.getLocation().getName());
|
|
85
|
+
}
|
|
86
|
+
if (node.getContentClassName() !== undefined) {
|
|
87
|
+
className += " " + node.getContentClassName();
|
|
88
|
+
}
|
|
89
|
+
return (_jsxs(_Fragment, { children: [overlay, _jsx("div", { ref: selfRef, style: style, className: className, "data-layout-path": path })] }));
|
|
90
|
+
};
|
|
91
|
+
//# sourceMappingURL=Tab.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Tab.js","sourceRoot":"","sources":["../../../src/view/Tab.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
import { I18nLabel } from "../I18nLabel";
|
|
4
|
+
import { Actions } from "../model/Actions";
|
|
5
|
+
import { ICloseType } from "../model/ICloseType";
|
|
6
|
+
import { CLASSES } from "../Types";
|
|
7
|
+
import { getRenderStateEx, isAuxMouseEvent } from "./Utils";
|
|
8
|
+
/** @internal */
|
|
9
|
+
export const TabButton = (props) => {
|
|
10
|
+
const { layout, node, selected, path } = props;
|
|
11
|
+
const selfRef = React.useRef(null);
|
|
12
|
+
const contentRef = React.useRef(null);
|
|
13
|
+
const icons = layout.getIcons();
|
|
14
|
+
React.useLayoutEffect(() => {
|
|
15
|
+
node.setTabRect(layout.getBoundingClientRect(selfRef.current));
|
|
16
|
+
if (layout.getEditingTab() === node) {
|
|
17
|
+
contentRef.current.select();
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
const onDragStart = (event) => {
|
|
21
|
+
if (node.isEnableDrag()) {
|
|
22
|
+
event.stopPropagation(); // prevent starting a tabset drag as well
|
|
23
|
+
layout.setDragNode(event.nativeEvent, node);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
event.preventDefault();
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
const onDragEnd = (event) => {
|
|
30
|
+
layout.clearDragMain();
|
|
31
|
+
};
|
|
32
|
+
const onAuxMouseClick = (event) => {
|
|
33
|
+
if (isAuxMouseEvent(event)) {
|
|
34
|
+
layout.auxMouseClick(node, event);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
const onContextMenu = (event) => {
|
|
38
|
+
layout.showContextMenu(node, event);
|
|
39
|
+
};
|
|
40
|
+
const onClick = () => {
|
|
41
|
+
layout.doAction(Actions.selectTab(node.getId()));
|
|
42
|
+
};
|
|
43
|
+
const onDoubleClick = (event) => {
|
|
44
|
+
if (node.isEnableRename()) {
|
|
45
|
+
onRename();
|
|
46
|
+
event.stopPropagation();
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
const onRename = () => {
|
|
50
|
+
layout.setEditingTab(node);
|
|
51
|
+
layout.getCurrentDocument().body.addEventListener("pointerdown", onEndEdit);
|
|
52
|
+
};
|
|
53
|
+
const onEndEdit = (event) => {
|
|
54
|
+
if (event.target !== contentRef.current) {
|
|
55
|
+
layout.getCurrentDocument().body.removeEventListener("pointerdown", onEndEdit);
|
|
56
|
+
layout.setEditingTab(undefined);
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
const isClosable = () => {
|
|
60
|
+
const closeType = node.getCloseType();
|
|
61
|
+
if (selected || closeType === ICloseType.Always) {
|
|
62
|
+
return true;
|
|
63
|
+
}
|
|
64
|
+
if (closeType === ICloseType.Visible) {
|
|
65
|
+
// not selected but x should be visible due to hover
|
|
66
|
+
if (window.matchMedia && window.matchMedia("(hover: hover) and (pointer: fine)").matches) {
|
|
67
|
+
return true;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
return false;
|
|
71
|
+
};
|
|
72
|
+
const onClose = (event) => {
|
|
73
|
+
if (isClosable()) {
|
|
74
|
+
layout.doAction(Actions.deleteTab(node.getId()));
|
|
75
|
+
event.stopPropagation();
|
|
76
|
+
}
|
|
77
|
+
};
|
|
78
|
+
const onClosePointerDown = (event) => {
|
|
79
|
+
event.stopPropagation();
|
|
80
|
+
};
|
|
81
|
+
const onTextBoxPointerDown = (event) => {
|
|
82
|
+
event.stopPropagation();
|
|
83
|
+
};
|
|
84
|
+
const onTextBoxKeyPress = (event) => {
|
|
85
|
+
if (event.code === 'Escape') {
|
|
86
|
+
// esc
|
|
87
|
+
layout.setEditingTab(undefined);
|
|
88
|
+
}
|
|
89
|
+
else if (event.code === 'Enter' || event.code === 'NumpadEnter') {
|
|
90
|
+
// enter
|
|
91
|
+
layout.setEditingTab(undefined);
|
|
92
|
+
layout.doAction(Actions.renameTab(node.getId(), event.target.value));
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
const cm = layout.getClassName;
|
|
96
|
+
const parentNode = node.getParent();
|
|
97
|
+
const isStretch = parentNode.isEnableSingleTabStretch() && parentNode.getChildren().length === 1;
|
|
98
|
+
let baseClassName = isStretch ? CLASSES.FLEXLAYOUT__TAB_BUTTON_STRETCH : CLASSES.FLEXLAYOUT__TAB_BUTTON;
|
|
99
|
+
let classNames = cm(baseClassName);
|
|
100
|
+
classNames += " " + cm(baseClassName + "_" + parentNode.getTabLocation());
|
|
101
|
+
if (!isStretch) {
|
|
102
|
+
if (selected) {
|
|
103
|
+
classNames += " " + cm(baseClassName + "--selected");
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
classNames += " " + cm(baseClassName + "--unselected");
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
if (node.getClassName() !== undefined) {
|
|
110
|
+
classNames += " " + node.getClassName();
|
|
111
|
+
}
|
|
112
|
+
const renderState = getRenderStateEx(layout, node);
|
|
113
|
+
let content = renderState.content ? (_jsx("div", { className: cm(CLASSES.FLEXLAYOUT__TAB_BUTTON_CONTENT), children: renderState.content })) : null;
|
|
114
|
+
const leading = renderState.leading ? (_jsx("div", { className: cm(CLASSES.FLEXLAYOUT__TAB_BUTTON_LEADING), children: renderState.leading })) : null;
|
|
115
|
+
if (layout.getEditingTab() === node) {
|
|
116
|
+
content = (_jsx("input", { ref: contentRef, className: cm(CLASSES.FLEXLAYOUT__TAB_BUTTON_TEXTBOX), "data-layout-path": path + "/textbox", type: "text", autoFocus: true, defaultValue: node.getName(), onKeyDown: onTextBoxKeyPress, onPointerDown: onTextBoxPointerDown }));
|
|
117
|
+
}
|
|
118
|
+
if (node.isEnableClose() && !isStretch) {
|
|
119
|
+
const closeTitle = layout.i18nName(I18nLabel.Close_Tab);
|
|
120
|
+
renderState.buttons.push(_jsx("div", { "data-layout-path": path + "/button/close", title: closeTitle, className: cm(CLASSES.FLEXLAYOUT__TAB_BUTTON_TRAILING), onPointerDown: onClosePointerDown, onClick: onClose, children: (typeof icons.close === "function") ? icons.close(node) : icons.close }, "close"));
|
|
121
|
+
}
|
|
122
|
+
return (_jsxs("div", { ref: selfRef, "data-layout-path": path, className: classNames, onClick: onClick, onAuxClick: onAuxMouseClick, onContextMenu: onContextMenu, title: node.getHelpText(), draggable: true, onDragStart: onDragStart, onDragEnd: onDragEnd, onDoubleClick: onDoubleClick, children: [leading, content, renderState.buttons] }));
|
|
123
|
+
};
|
|
124
|
+
//# sourceMappingURL=TabButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TabButton.js","sourceRoot":"","sources":["../../../src/view/TabButton.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { CLASSES } from "../Types";
|
|
3
|
+
import { getRenderStateEx } from "./Utils";
|
|
4
|
+
/** @internal */
|
|
5
|
+
export const TabButtonStamp = (props) => {
|
|
6
|
+
const { layout, node } = props;
|
|
7
|
+
const cm = layout.getClassName;
|
|
8
|
+
let classNames = cm(CLASSES.FLEXLAYOUT__TAB_BUTTON_STAMP);
|
|
9
|
+
const renderState = getRenderStateEx(layout, node);
|
|
10
|
+
let content = renderState.content ? (_jsx("div", { className: cm(CLASSES.FLEXLAYOUT__TAB_BUTTON_CONTENT), children: renderState.content }))
|
|
11
|
+
: node.getNameForOverflowMenu();
|
|
12
|
+
const leading = renderState.leading ? (_jsx("div", { className: cm(CLASSES.FLEXLAYOUT__TAB_BUTTON_LEADING), children: renderState.leading })) : null;
|
|
13
|
+
return (_jsxs("div", { className: classNames, title: node.getHelpText(), children: [leading, content] }));
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=TabButtonStamp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TabButtonStamp.js","sourceRoot":"","sources":["../../../src/view/TabButtonStamp.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAQ3C,gBAAgB;AAChB,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAA2B,EAAE,EAAE;IAC1D,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC;IAE/B,MAAM,EAAE,GAAG,MAAM,CAAC,YAAY,CAAC;IAE/B,IAAI,UAAU,GAAG,EAAE,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC;IAE1D,MAAM,WAAW,GAAG,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAEnD,IAAI,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAChC,cAAK,SAAS,EAAE,EAAE,CAAC,OAAO,CAAC,8BAA8B,CAAC,YACrD,WAAW,CAAC,OAAO,GAClB,CAAC;QACP,CAAC,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAEpC,MAAM,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAClC,cAAK,SAAS,EAAE,EAAE,CAAC,OAAO,CAAC,8BAA8B,CAAC,YACrD,WAAW,CAAC,OAAO,GAClB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAEnB,OAAO,CACH,eACI,SAAS,EAAE,UAAU,EACrB,KAAK,EAAE,IAAI,CAAC,WAAW,EAAE,aAExB,OAAO,EACP,OAAO,IACN,CACT,CAAC;AACN,CAAC,CAAC"}
|
|
@@ -0,0 +1,266 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import { Orientation } from "../Orientation";
|
|
3
|
+
import { startDrag } from "./Utils";
|
|
4
|
+
/** @internal */
|
|
5
|
+
export const useTabOverflow = (layout, node, orientation, tabStripRef, miniScrollRef, tabClassName) => {
|
|
6
|
+
const [hiddenTabs, setHiddenTabs] = React.useState([]);
|
|
7
|
+
const [isShowHiddenTabs, setShowHiddenTabs] = React.useState(false);
|
|
8
|
+
const [isDockStickyButtons, setDockStickyButtons] = React.useState(false);
|
|
9
|
+
const selfRef = React.useRef(null);
|
|
10
|
+
const userControlledPositionRef = React.useRef(false);
|
|
11
|
+
const updateHiddenTabsTimerRef = React.useRef(undefined);
|
|
12
|
+
const hiddenTabsRef = React.useRef([]);
|
|
13
|
+
const thumbInternalPos = React.useRef(0);
|
|
14
|
+
const repositioningRef = React.useRef(false);
|
|
15
|
+
hiddenTabsRef.current = hiddenTabs;
|
|
16
|
+
// if node id changes (new model) then reset scroll to 0
|
|
17
|
+
React.useLayoutEffect(() => {
|
|
18
|
+
if (tabStripRef.current) {
|
|
19
|
+
setScrollPosition(0);
|
|
20
|
+
}
|
|
21
|
+
}, [node.getId()]);
|
|
22
|
+
// if selected node or tabset/border rectangle change then unset usercontrolled (so selected tab will be kept in view)
|
|
23
|
+
React.useLayoutEffect(() => {
|
|
24
|
+
userControlledPositionRef.current = false;
|
|
25
|
+
}, [node.getSelectedNode(), node.getRect().width, node.getRect().height]);
|
|
26
|
+
React.useLayoutEffect(() => {
|
|
27
|
+
checkForOverflow(); // if tabs + sticky buttons length > scroll area => move sticky buttons to right buttons
|
|
28
|
+
if (userControlledPositionRef.current === false) {
|
|
29
|
+
scrollIntoView();
|
|
30
|
+
}
|
|
31
|
+
updateScrollMetrics();
|
|
32
|
+
updateHiddenTabs();
|
|
33
|
+
});
|
|
34
|
+
function scrollIntoView() {
|
|
35
|
+
const selectedTabNode = node.getSelectedNode();
|
|
36
|
+
if (selectedTabNode && tabStripRef.current) {
|
|
37
|
+
const stripRect = layout.getBoundingClientRect(tabStripRef.current);
|
|
38
|
+
const selectedRect = selectedTabNode.getTabRect();
|
|
39
|
+
let shift = getNear(stripRect) - getNear(selectedRect);
|
|
40
|
+
if (shift > 0 || getSize(selectedRect) > getSize(stripRect)) {
|
|
41
|
+
setScrollPosition(getScrollPosition(tabStripRef.current) - shift);
|
|
42
|
+
repositioningRef.current = true; // prevent onScroll setting userControlledPosition
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
shift = getFar(selectedRect) - getFar(stripRect);
|
|
46
|
+
if (shift > 0) {
|
|
47
|
+
setScrollPosition(getScrollPosition(tabStripRef.current) + shift);
|
|
48
|
+
repositioningRef.current = true;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
const updateScrollMetrics = () => {
|
|
54
|
+
if (tabStripRef.current && miniScrollRef.current) {
|
|
55
|
+
const t = tabStripRef.current;
|
|
56
|
+
const s = miniScrollRef.current;
|
|
57
|
+
const size = getElementSize(t);
|
|
58
|
+
const scrollSize = getScrollSize(t);
|
|
59
|
+
const position = getScrollPosition(t);
|
|
60
|
+
if (scrollSize > size && scrollSize > 0) {
|
|
61
|
+
let thumbSize = size * size / scrollSize;
|
|
62
|
+
let adjust = 0;
|
|
63
|
+
if (thumbSize < 20) {
|
|
64
|
+
adjust = 20 - thumbSize;
|
|
65
|
+
thumbSize = 20;
|
|
66
|
+
}
|
|
67
|
+
const thumbPos = position * (size - adjust) / scrollSize;
|
|
68
|
+
if (orientation === Orientation.HORZ) {
|
|
69
|
+
s.style.width = thumbSize + "px";
|
|
70
|
+
s.style.left = thumbPos + "px";
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
s.style.height = thumbSize + "px";
|
|
74
|
+
s.style.top = thumbPos + "px";
|
|
75
|
+
}
|
|
76
|
+
s.style.display = "block";
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
s.style.display = "none";
|
|
80
|
+
}
|
|
81
|
+
if (orientation === Orientation.HORZ) {
|
|
82
|
+
s.style.bottom = "0px";
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
s.style.right = "0px";
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
const updateHiddenTabs = () => {
|
|
90
|
+
const newHiddenTabs = findHiddenTabs();
|
|
91
|
+
const showHidden = newHiddenTabs.length > 0;
|
|
92
|
+
if (showHidden !== isShowHiddenTabs) {
|
|
93
|
+
setShowHiddenTabs(showHidden);
|
|
94
|
+
}
|
|
95
|
+
if (updateHiddenTabsTimerRef.current === undefined) {
|
|
96
|
+
// throttle updates to prevent Maximum update depth exceeded error
|
|
97
|
+
updateHiddenTabsTimerRef.current = setTimeout(() => {
|
|
98
|
+
const newHiddenTabs = findHiddenTabs();
|
|
99
|
+
if (!arraysEqual(newHiddenTabs, hiddenTabsRef.current)) {
|
|
100
|
+
setHiddenTabs(newHiddenTabs);
|
|
101
|
+
}
|
|
102
|
+
updateHiddenTabsTimerRef.current = undefined;
|
|
103
|
+
}, 100);
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
const onScroll = () => {
|
|
107
|
+
if (!repositioningRef.current) {
|
|
108
|
+
userControlledPositionRef.current = true;
|
|
109
|
+
}
|
|
110
|
+
repositioningRef.current = false;
|
|
111
|
+
updateScrollMetrics();
|
|
112
|
+
updateHiddenTabs();
|
|
113
|
+
};
|
|
114
|
+
const onScrollPointerDown = (event) => {
|
|
115
|
+
var _a;
|
|
116
|
+
event.stopPropagation();
|
|
117
|
+
miniScrollRef.current.setPointerCapture(event.pointerId);
|
|
118
|
+
const r = (_a = miniScrollRef.current) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect();
|
|
119
|
+
if (orientation === Orientation.HORZ) {
|
|
120
|
+
thumbInternalPos.current = event.clientX - r.x;
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
thumbInternalPos.current = event.clientY - r.y;
|
|
124
|
+
}
|
|
125
|
+
startDrag(event.currentTarget.ownerDocument, event, onDragMove, onDragEnd, onDragCancel);
|
|
126
|
+
};
|
|
127
|
+
const onDragMove = (x, y) => {
|
|
128
|
+
if (tabStripRef.current && miniScrollRef.current) {
|
|
129
|
+
const t = tabStripRef.current;
|
|
130
|
+
const s = miniScrollRef.current;
|
|
131
|
+
const size = getElementSize(t);
|
|
132
|
+
const scrollSize = getScrollSize(t);
|
|
133
|
+
const thumbSize = getElementSize(s);
|
|
134
|
+
const r = t.getBoundingClientRect();
|
|
135
|
+
let thumb = 0;
|
|
136
|
+
if (orientation === Orientation.HORZ) {
|
|
137
|
+
thumb = x - r.x - thumbInternalPos.current;
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
thumb = y - r.y - thumbInternalPos.current;
|
|
141
|
+
}
|
|
142
|
+
thumb = Math.max(0, Math.min(scrollSize - thumbSize, thumb));
|
|
143
|
+
if (size > 0) {
|
|
144
|
+
const scrollPos = thumb * scrollSize / size;
|
|
145
|
+
setScrollPosition(scrollPos);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
};
|
|
149
|
+
const onDragEnd = () => {
|
|
150
|
+
};
|
|
151
|
+
const onDragCancel = () => {
|
|
152
|
+
};
|
|
153
|
+
const checkForOverflow = () => {
|
|
154
|
+
if (tabStripRef.current) {
|
|
155
|
+
const strip = tabStripRef.current;
|
|
156
|
+
const tabContainer = strip.firstElementChild;
|
|
157
|
+
const offset = isDockStickyButtons ? 10 : 0; // prevents flashing, after sticky buttons docked set, must be 10 pixels smaller before unsetting
|
|
158
|
+
const dock = (getElementSize(tabContainer) + offset) > getElementSize(tabStripRef.current);
|
|
159
|
+
if (dock !== isDockStickyButtons) {
|
|
160
|
+
setDockStickyButtons(dock);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
};
|
|
164
|
+
const findHiddenTabs = () => {
|
|
165
|
+
const hidden = [];
|
|
166
|
+
if (tabStripRef.current) {
|
|
167
|
+
const strip = tabStripRef.current;
|
|
168
|
+
const stripRect = strip.getBoundingClientRect();
|
|
169
|
+
const visibleNear = getNear(stripRect) - 1;
|
|
170
|
+
const visibleFar = getFar(stripRect) + 1;
|
|
171
|
+
const tabContainer = strip.firstElementChild;
|
|
172
|
+
let i = 0;
|
|
173
|
+
Array.from(tabContainer.children).forEach((child) => {
|
|
174
|
+
const tabRect = child.getBoundingClientRect();
|
|
175
|
+
if (child.classList.contains(tabClassName)) {
|
|
176
|
+
if (getNear(tabRect) < visibleNear || getFar(tabRect) > visibleFar) {
|
|
177
|
+
hidden.push(i);
|
|
178
|
+
}
|
|
179
|
+
i++;
|
|
180
|
+
}
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
return hidden;
|
|
184
|
+
};
|
|
185
|
+
const onMouseWheel = (event) => {
|
|
186
|
+
if (tabStripRef.current) {
|
|
187
|
+
if (node.getChildren().length === 0)
|
|
188
|
+
return;
|
|
189
|
+
let delta = 0;
|
|
190
|
+
if (Math.abs(event.deltaY) > 0) {
|
|
191
|
+
delta = -event.deltaY;
|
|
192
|
+
if (event.deltaMode === 1) {
|
|
193
|
+
// DOM_DELTA_LINE 0x01 The delta values are specified in lines.
|
|
194
|
+
delta *= 40;
|
|
195
|
+
}
|
|
196
|
+
const newPos = getScrollPosition(tabStripRef.current) - delta;
|
|
197
|
+
const maxScroll = getScrollSize(tabStripRef.current) - getElementSize(tabStripRef.current);
|
|
198
|
+
const p = Math.max(0, Math.min(maxScroll, newPos));
|
|
199
|
+
setScrollPosition(p);
|
|
200
|
+
event.stopPropagation();
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
};
|
|
204
|
+
// orientation helpers:
|
|
205
|
+
const getNear = (rect) => {
|
|
206
|
+
if (orientation === Orientation.HORZ) {
|
|
207
|
+
return rect.x;
|
|
208
|
+
}
|
|
209
|
+
else {
|
|
210
|
+
return rect.y;
|
|
211
|
+
}
|
|
212
|
+
};
|
|
213
|
+
const getFar = (rect) => {
|
|
214
|
+
if (orientation === Orientation.HORZ) {
|
|
215
|
+
return rect.right;
|
|
216
|
+
}
|
|
217
|
+
else {
|
|
218
|
+
return rect.bottom;
|
|
219
|
+
}
|
|
220
|
+
};
|
|
221
|
+
const getElementSize = (elm) => {
|
|
222
|
+
if (orientation === Orientation.HORZ) {
|
|
223
|
+
return elm.clientWidth;
|
|
224
|
+
}
|
|
225
|
+
else {
|
|
226
|
+
return elm.clientHeight;
|
|
227
|
+
}
|
|
228
|
+
};
|
|
229
|
+
const getSize = (rect) => {
|
|
230
|
+
if (orientation === Orientation.HORZ) {
|
|
231
|
+
return rect.width;
|
|
232
|
+
}
|
|
233
|
+
else {
|
|
234
|
+
return rect.height;
|
|
235
|
+
}
|
|
236
|
+
};
|
|
237
|
+
const getScrollSize = (elm) => {
|
|
238
|
+
if (orientation === Orientation.HORZ) {
|
|
239
|
+
return elm.scrollWidth;
|
|
240
|
+
}
|
|
241
|
+
else {
|
|
242
|
+
return elm.scrollHeight;
|
|
243
|
+
}
|
|
244
|
+
};
|
|
245
|
+
const setScrollPosition = (p) => {
|
|
246
|
+
if (orientation === Orientation.HORZ) {
|
|
247
|
+
tabStripRef.current.scrollLeft = p;
|
|
248
|
+
}
|
|
249
|
+
else {
|
|
250
|
+
tabStripRef.current.scrollTop = p;
|
|
251
|
+
}
|
|
252
|
+
};
|
|
253
|
+
const getScrollPosition = (elm) => {
|
|
254
|
+
if (orientation === Orientation.HORZ) {
|
|
255
|
+
return elm.scrollLeft;
|
|
256
|
+
}
|
|
257
|
+
else {
|
|
258
|
+
return elm.scrollTop;
|
|
259
|
+
}
|
|
260
|
+
};
|
|
261
|
+
return { selfRef, userControlledPositionRef, onScroll, onScrollPointerDown, hiddenTabs, onMouseWheel, isDockStickyButtons, isShowHiddenTabs };
|
|
262
|
+
};
|
|
263
|
+
function arraysEqual(arr1, arr2) {
|
|
264
|
+
return arr1.length === arr2.length && arr1.every((val, index) => val === arr2[index]);
|
|
265
|
+
}
|
|
266
|
+
//# sourceMappingURL=TabOverflowHook.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TabOverflowHook.js","sourceRoot":"","sources":["../../../src/view/TabOverflowHook.tsx"],"names":[],"mappings":"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"}
|