Tree Control

This commit is contained in:
Peter Paul Kirschner 2024-10-06 21:16:27 +02:00
parent aecce820f7
commit 5a5709042e
13 changed files with 717 additions and 452 deletions

View File

@ -15,13 +15,14 @@
"@microsoft/sp-office-ui-fabric-core": "1.20.0",
"@microsoft/sp-property-pane": "1.20.0",
"@microsoft/sp-webpart-base": "1.20.0",
"@nosferatu500/react-sortable-tree": "^4.4.0",
"@pnp/graph": "^4.5.0",
"@pnp/sp": "^4.5.0",
"@pnp/spfx-controls-react": "^4.0.0-beta.6059091",
"@pnp/spfx-property-controls": "^3.18",
"@pnp/spfx-property-controls": "^4.0.0-beta.6059131",
"@types/react-sortable-tree": "^0.3.23",
"react": "17.0.1",
"react-dom": "17.0.1",
"react-sortable-tree-patch-react-17": "^2.9.0",
"tslib": "2.3.1"
},
"devDependencies": {
@ -8684,82 +8685,6 @@
"node": ">= 8"
}
},
"node_modules/@nosferatu500/react-sortable-tree": {
"version": "4.4.0",
"resolved": "https://registry.npmjs.org/@nosferatu500/react-sortable-tree/-/react-sortable-tree-4.4.0.tgz",
"integrity": "sha512-TN3IYLM1y+ZZAM3ulMXnxwcwX6TPokTczkf3UZ9h0dZ/GE3wSlC1Db4crFjvrEgyHWRGX73lA779Um9wtS9tAQ==",
"dependencies": {
"@nosferatu500/react-dnd-scrollzone": "^2.0.10",
"lodash.isequal": "^4.5.0",
"react-dnd": "14.0.4",
"react-dnd-html5-backend": "^14.1.0",
"react-virtuoso": "^4.3.1"
},
"engines": {
"node": ">=16"
},
"peerDependencies": {
"react": "^17.0.0 || ^18.0.0",
"react-dnd": "14.0.4",
"react-dom": "^17.0.0 || ^18.0.0"
}
},
"node_modules/@nosferatu500/react-sortable-tree/node_modules/@nosferatu500/react-dnd-scrollzone": {
"version": "2.0.10",
"resolved": "https://registry.npmjs.org/@nosferatu500/react-dnd-scrollzone/-/react-dnd-scrollzone-2.0.10.tgz",
"integrity": "sha512-PBJtyBQrm47ifesOfIOsJd2SaxSpjkfKSoQOHewkI4UeYLyEc4hX0BY3vlVxW0zzak2+IneJghmGnp5lznVo6A==",
"dependencies": {
"hoist-non-react-statics": "^3.3.2",
"lodash.throttle": "^4.1.1"
},
"engines": {
"node": ">=16"
},
"peerDependencies": {
"react": ">=17.0.2",
"react-dnd": "14.0.4",
"react-dom": ">=17.0.2"
}
},
"node_modules/@nosferatu500/react-sortable-tree/node_modules/@types/node": {
"version": "22.7.4",
"resolved": "https://registry.npmjs.org/@types/node/-/node-22.7.4.tgz",
"integrity": "sha512-y+NPi1rFzDs1NdQHHToqeiX2TIS79SWEAw9GYhkkx8bD0ChpfqC+n2j5OXOCpzfojBEBt6DnEnnG9MY0zk1XLg==",
"optional": true,
"peer": true,
"dependencies": {
"undici-types": "~6.19.2"
}
},
"node_modules/@nosferatu500/react-sortable-tree/node_modules/react-dnd": {
"version": "14.0.4",
"resolved": "https://registry.npmjs.org/react-dnd/-/react-dnd-14.0.4.tgz",
"integrity": "sha512-AFJJXzUIWp5WAhgvI85ESkDCawM0lhoVvfo/lrseLXwFdH3kEO3v8I2C81QPqBW2UEyJBIPStOhPMGYGFtq/bg==",
"dependencies": {
"@react-dnd/invariant": "^2.0.0",
"@react-dnd/shallowequal": "^2.0.0",
"dnd-core": "14.0.1",
"fast-deep-equal": "^3.1.3",
"hoist-non-react-statics": "^3.3.2"
},
"peerDependencies": {
"@types/hoist-non-react-statics": ">= 3.3.1",
"@types/node": ">= 12",
"@types/react": ">= 16",
"react": ">= 16.14"
},
"peerDependenciesMeta": {
"@types/hoist-non-react-statics": {
"optional": true
},
"@types/node": {
"optional": true
},
"@types/react": {
"optional": true
}
}
},
"node_modules/@opentelemetry/api": {
"version": "1.9.0",
"resolved": "https://registry.npmjs.org/@opentelemetry/api/-/api-1.9.0.tgz",
@ -9647,19 +9572,18 @@
}
},
"node_modules/@pnp/spfx-property-controls": {
"version": "3.18.0",
"resolved": "https://registry.npmjs.org/@pnp/spfx-property-controls/-/spfx-property-controls-3.18.0.tgz",
"integrity": "sha512-hEHdfZHqv+y4q0qoDElx4YlfZ7O+GOwbBlHtgML8ztgo/6uP3i/NWnQDY5D+E2UJyo3eb2b4eULUDCtH446nyg==",
"version": "4.0.0-beta.6059131",
"resolved": "https://registry.npmjs.org/@pnp/spfx-property-controls/-/spfx-property-controls-4.0.0-beta.6059131.tgz",
"integrity": "sha512-kHMoz8xwEHtFgoQpWajawwpaOO2tx6GgLMvVRNE7VsPtLMsqrhKWAIsFuzxpt6yN9xzOMk+B/b4xdG5PxCfYyA==",
"hasInstallScript": true,
"dependencies": {
"@fluentui/react": "8.106.4",
"@fluentui/react-components": "^9.48.0",
"@microsoft/sp-adaptive-card-extension-base": "1.19.0",
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-lodash-subset": "1.19.0",
"@microsoft/sp-office-ui-fabric-core": "1.19.0",
"@microsoft/sp-property-pane": "1.19.0",
"@microsoft/sp-webpart-base": "1.19.0",
"@fluentui/react": "^7.199.1",
"@microsoft/sp-adaptive-card-extension-base": "1.17.3",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-lodash-subset": "1.17.3",
"@microsoft/sp-office-ui-fabric-core": "1.17.3",
"@microsoft/sp-property-pane": "1.17.3",
"@microsoft/sp-webpart-base": "1.17.3",
"@monaco-editor/loader": "^1.2.0",
"@pnp/common": "1.3.11",
"@pnp/logging": "1.3.11",
@ -9673,53 +9597,94 @@
"lodash.omit": "4.5.0",
"markdown-to-jsx": "^6.11.4",
"monaco-editor": "^0.32.1",
"office-ui-fabric-react": "^7.199.1",
"react": "17.0.1",
"react-ace": "10.1.0",
"react-dom": "17.0.1"
},
"engines": {
"node": ">=16.13.0 <17.0.0 || >=18.17.1 <19.0.0"
"node": ">=16.13.0 <17.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-adaptive-card-extension-base": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-adaptive-card-extension-base/-/sp-adaptive-card-extension-base-1.19.0.tgz",
"integrity": "sha512-tCJXQ8jIuJZ9okAg3zGYOnDlGJCYZY4/JPt5cmCNd/jQoqd1YH69qa8AO74PjdeK5CUVC5Eq//7VVyw3GHg5SA==",
"node_modules/@pnp/spfx-property-controls/node_modules/@azure/msal-browser": {
"version": "2.28.1",
"resolved": "https://registry.npmjs.org/@azure/msal-browser/-/msal-browser-2.28.1.tgz",
"integrity": "sha512-5uAfwpNGBSRzBGTSS+5l4Zw6msPV7bEmq99n0U3n/N++iTcha+nIp1QujxTPuOLHmTNCeySdMx9qzGqWuy22zQ==",
"deprecated": "A newer major version of this library is available. Please upgrade to the latest available version.",
"dependencies": {
"@microsoft/sp-component-base": "1.19.0",
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-diagnostics": "1.19.0",
"@microsoft/sp-http": "1.19.0",
"@microsoft/sp-http-base": "1.19.0",
"@microsoft/sp-loader": "1.19.0",
"@microsoft/sp-lodash-subset": "1.19.0",
"@microsoft/sp-module-interfaces": "1.20.1",
"@microsoft/sp-property-pane": "1.19.0",
"@microsoft/teams-js-v2": "npm:@microsoft/teams-js@2.12.0",
"adaptivecards": "2.11.2",
"@azure/msal-common": "^7.3.0"
},
"engines": {
"node": ">=0.8.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@azure/msal-common": {
"version": "7.6.0",
"resolved": "https://registry.npmjs.org/@azure/msal-common/-/msal-common-7.6.0.tgz",
"integrity": "sha512-XqfbglUTVLdkHQ8F9UQJtKseRr3sSnr9ysboxtoswvaMVaEfvyLtMoHv9XdKUfOc0qKGzNgRFd9yRjIWVepl6Q==",
"engines": {
"node": ">=0.8.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@fluentui/react": {
"version": "7.204.0",
"resolved": "https://registry.npmjs.org/@fluentui/react/-/react-7.204.0.tgz",
"integrity": "sha512-WQKHcO6cboGO0eCPsiNSzUwnMWBmAvdltu4X0tvXwb+q8W3wZzCQiU1voDVYNm4Nz/Jgiiy8jbMcesmNAq7jsw==",
"dependencies": {
"@uifabric/set-version": "^7.0.24",
"office-ui-fabric-react": "^7.204.0",
"tslib": "^1.10.0"
},
"peerDependencies": {
"@types/react": ">=16.8.0 <18.0.0",
"@types/react-dom": ">=16.8.0 <18.0.0",
"react": ">=16.8.0 <18.0.0",
"react-dom": ">=16.8.0 <18.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@fluentui/react/node_modules/tslib": {
"version": "1.14.1",
"resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz",
"integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg=="
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-adaptive-card-extension-base": {
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-adaptive-card-extension-base/-/sp-adaptive-card-extension-base-1.17.3.tgz",
"integrity": "sha512-3rXAxLzwCFUIP2ngTB1aurTMiFwSYP1MzvuEmj4NW5zElhYg+kFr0MMqCrBYkSdEXKDLZ++B9b5uKxAInW+gMQ==",
"dependencies": {
"@microsoft/sp-component-base": "1.17.3",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-diagnostics": "1.17.3",
"@microsoft/sp-http": "1.17.3",
"@microsoft/sp-http-base": "1.17.3",
"@microsoft/sp-loader": "1.17.3",
"@microsoft/sp-lodash-subset": "1.17.3",
"@microsoft/sp-module-interfaces": "1.17.3",
"@microsoft/sp-property-pane": "1.17.3",
"adaptivecards": "2.11.1",
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-component-base": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-component-base/-/sp-component-base-1.19.0.tgz",
"integrity": "sha512-FtJMBewzS4+8tUSTE+K5ndiWvEbWWhu0uIP3M265d/+LDUzp1UX9RcpWHlcqIAdHw9P6VaX+5ADsXE0XDn4jZw==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-component-base/-/sp-component-base-1.17.3.tgz",
"integrity": "sha512-7Xey4caHNTkz5EtN6BVRj/PUCaLMVV+dYMZbwgoa9grIUFYwGKP8M0m3RZRUUNX9EPaumo+5QUufVVl159nHKA==",
"dependencies": {
"@fluentui/react": "^8.110.12",
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-diagnostics": "1.19.0",
"@microsoft/sp-dynamic-data": "1.19.0",
"@microsoft/sp-http": "1.19.0",
"@microsoft/sp-lodash-subset": "1.19.0",
"@microsoft/sp-module-interfaces": "1.20.1",
"@microsoft/sp-page-context": "1.19.0",
"@fluentui/react": "^8.106.4",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-diagnostics": "1.17.3",
"@microsoft/sp-dynamic-data": "1.17.3",
"@microsoft/sp-http": "1.17.3",
"@microsoft/sp-lodash-subset": "1.17.3",
"@microsoft/sp-module-interfaces": "1.17.3",
"@microsoft/sp-page-context": "1.17.3",
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-component-base/node_modules/@fluentui/react": {
@ -9750,17 +9715,17 @@
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-core-library": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-core-library/-/sp-core-library-1.19.0.tgz",
"integrity": "sha512-FzXy27IyS5acxgDvxGlycaoB1RLH9Mq0TDYT0UXrch9wBiQ7Cs2Lvh2qJbT954KdtrR5pyz7mWJP2MKPXKSmyA==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-core-library/-/sp-core-library-1.17.3.tgz",
"integrity": "sha512-NEMW4xHsiUyFhQnmj2pU4pEQB1Dy5QoZNU0Qys66PXdJFwJgrGn9PUjRReZlN3dyX1jwSzLCgzWU73bJrcB/1w==",
"dependencies": {
"@microsoft/sp-lodash-subset": "1.19.0",
"@microsoft/sp-module-interfaces": "1.20.1",
"@microsoft/sp-odata-types": "1.19.0",
"@microsoft/sp-lodash-subset": "1.17.3",
"@microsoft/sp-module-interfaces": "1.17.3",
"@microsoft/sp-odata-types": "1.17.3",
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
},
"peerDependencies": {
"@types/react": ">=16.9.51 <18.0.0",
@ -9770,73 +9735,75 @@
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-diagnostics": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-diagnostics/-/sp-diagnostics-1.19.0.tgz",
"integrity": "sha512-w5D3oz8sbEwOPStOupjJwT/1Ud0ujwbQ27SCBPncVYO/EXD4RWTM50+ZLoZepPnK0GDX0FCZsYMDaKnNZHlB6A==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-diagnostics/-/sp-diagnostics-1.17.3.tgz",
"integrity": "sha512-vUFkFr78QCEEXgiWNbWjI8mUUDKPXVX0/eSVuAClXhENmxRqhS4nvkckTm/acmXvcw8az3G1r2ou6Q7hFX3d9Q==",
"dependencies": {
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-lodash-subset": "1.19.0"
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-lodash-subset": "1.17.3"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-dynamic-data": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-dynamic-data/-/sp-dynamic-data-1.19.0.tgz",
"integrity": "sha512-yKHCyV+YXI9HhkTWBVF/odGWofjQFRw9JaZ8C06JrmGaJ7raQc8d0nTuc13Y/1tpGmAd/tvbkcqd006k8WvJsw==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-dynamic-data/-/sp-dynamic-data-1.17.3.tgz",
"integrity": "sha512-+lE9U+28JjrV5Q5NucntkbLyx5LvdipQU0ppvti1SuEHCnetqPOVEI/axUjY1MbvmLBHngQUFj/U4UAIQse9KQ==",
"dependencies": {
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-diagnostics": "1.19.0",
"@microsoft/sp-lodash-subset": "1.19.0",
"@microsoft/sp-module-interfaces": "1.20.1",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-diagnostics": "1.17.3",
"@microsoft/sp-lodash-subset": "1.17.3",
"@microsoft/sp-module-interfaces": "1.17.3",
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-http": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-http/-/sp-http-1.19.0.tgz",
"integrity": "sha512-9tu580LgtkCheDYgYXHMDD3x6Plz5x1c3fTWSwWpjEOIFZGK/Fmse1c1YopQyLu/YUHinW+01TYnF/XyQywoKg==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-http/-/sp-http-1.17.3.tgz",
"integrity": "sha512-7ctnBEJd8ak4VLSPakMX42GF/DAz66RL5dlPJzx16e2pycJoNIKL0vBsEalZ5RWmkcjE6jGRi2xtSPwhIiJWlA==",
"dependencies": {
"@microsoft/microsoft-graph-clientv1": "npm:@microsoft/microsoft-graph-client@1.7.2-spfx",
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-diagnostics": "1.19.0",
"@microsoft/sp-http-base": "1.19.0",
"@microsoft/sp-http-msgraph": "1.19.0",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-diagnostics": "1.17.3",
"@microsoft/sp-http-base": "1.17.3",
"@microsoft/sp-http-msgraph": "1.17.3",
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-http-base": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-http-base/-/sp-http-base-1.19.0.tgz",
"integrity": "sha512-jd3eX9agA+r/BUuMFBPS+BR18OfH/+a5cJL0RVaB4jRUX6FplAaOgkMbG71orDc1I8WWG2MWgK+XZ419hPKPVw==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-http-base/-/sp-http-base-1.17.3.tgz",
"integrity": "sha512-D0KsLakRuR1iDZa27CSEhW84KPs9/BMIaezxK/M3076WyldRtA0zQwk8rwmoDgU3K3GqqspwP0T0KWT9QH3t4w==",
"dependencies": {
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-diagnostics": "1.19.0",
"@microsoft/sp-page-context": "1.19.0",
"@microsoft/teams-js-v2": "npm:@microsoft/teams-js@2.12.0",
"@azure/msal-browser": "2.28.1",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-diagnostics": "1.17.3",
"@microsoft/sp-page-context": "1.17.3",
"@microsoft/teams-js-v2": "npm:@microsoft/teams-js@2.9.1",
"adal-angular": "1.0.16",
"msal": "1.4.17",
"msalBrowserLegacy": "npm:@azure/msal-browser@2.22.0",
"msalLegacy": "npm:msal@1.4.12",
"tslib": "2.3.1"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-http-msgraph": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-http-msgraph/-/sp-http-msgraph-1.19.0.tgz",
"integrity": "sha512-wjRQ+VBenkqZg9GTHpV0Y7YWDEII3Kzihe2exdwBgLMZlUnf60M1222foHtGrd/PzyLyHbntuqzGfmE36VNlfQ==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-http-msgraph/-/sp-http-msgraph-1.17.3.tgz",
"integrity": "sha512-2ZbDZaNFGNg6nAvkOzEK0hjqkj9f+cN+ugZSFAANoF8wV7szYA/wRcLjvM+Kq3Ol7fGu/OrQeHrTEBWBekP2XQ==",
"dependencies": {
"@microsoft/microsoft-graph-clientv1": "npm:@microsoft/microsoft-graph-client@1.7.2-spfx",
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-diagnostics": "1.19.0",
"@microsoft/sp-http-base": "1.19.0",
"@microsoft/sp-loader": "1.19.0",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-diagnostics": "1.17.3",
"@microsoft/sp-http-base": "1.17.3",
"@microsoft/sp-loader": "1.17.3",
"tslib": "2.3.1"
},
"peerDependencies": {
@ -9844,21 +9811,21 @@
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-image-helper": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-image-helper/-/sp-image-helper-1.19.0.tgz",
"integrity": "sha512-tsgy9iy/8NqXqywYm0M+XBt1fAO03mwEccALoICNECU5CX+KRb/a80FfQ1CbaqvzQqeuAzFp48ZIHqFAgzxE9Q==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-image-helper/-/sp-image-helper-1.17.3.tgz",
"integrity": "sha512-Kbw/v2f3STTxcucRPBgJWuVaYY6K4oMhWK4WuSRWKFfOZX3xTlznzBbNQLf5OWTwrsDngoFDoyREI3spME5UbQ==",
"dependencies": {
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-diagnostics": "1.19.0",
"@microsoft/sp-http": "1.19.0",
"@microsoft/sp-http-base": "1.19.0",
"@microsoft/sp-loader": "1.19.0",
"@microsoft/sp-lodash-subset": "1.19.0",
"@microsoft/sp-page-context": "1.19.0",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-diagnostics": "1.17.3",
"@microsoft/sp-http": "1.17.3",
"@microsoft/sp-http-base": "1.17.3",
"@microsoft/sp-loader": "1.17.3",
"@microsoft/sp-lodash-subset": "1.17.3",
"@microsoft/sp-page-context": "1.17.3",
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
},
"peerDependencies": {
"@types/react": ">=16.9.51 <18.0.0",
@ -9868,20 +9835,20 @@
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-loader": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-loader/-/sp-loader-1.19.0.tgz",
"integrity": "sha512-KFQ7AvTXn+PKT5YzxZMvgrjRDq0UZxZp6MoZP14mjo/fJ/vU5SQJG1csWz/0MdTpv3OooxeqgstwOL2hM/cB4A==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-loader/-/sp-loader-1.17.3.tgz",
"integrity": "sha512-qmG5XoXSuHyAeryeuNQIGIEMKePEGkxmPhgULnGLX6chGKLimtVL+SzOc8+hVet49Rr1B6eIIMaIV6ajZx/qoQ==",
"dependencies": {
"@fluentui/react": "^8.110.12",
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-diagnostics": "1.19.0",
"@microsoft/sp-dynamic-data": "1.19.0",
"@microsoft/sp-http-base": "1.19.0",
"@microsoft/sp-lodash-subset": "1.19.0",
"@microsoft/sp-module-interfaces": "1.20.1",
"@microsoft/sp-odata-types": "1.19.0",
"@microsoft/sp-page-context": "1.19.0",
"@rushstack/loader-raw-script": "1.4.37",
"@fluentui/react": "^8.106.4",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-diagnostics": "1.17.3",
"@microsoft/sp-dynamic-data": "1.17.3",
"@microsoft/sp-http-base": "1.17.3",
"@microsoft/sp-lodash-subset": "1.17.3",
"@microsoft/sp-module-interfaces": "1.17.3",
"@microsoft/sp-odata-types": "1.17.3",
"@microsoft/sp-page-context": "1.17.3",
"@rushstack/loader-raw-script": "1.3.281",
"@types/requirejs": "2.1.29",
"raw-loader": "~0.5.1",
"react": "17.0.1",
@ -9890,7 +9857,7 @@
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
},
"peerDependencies": {
"@types/react": ">=16.9.51 <18.0.0",
@ -9925,87 +9892,87 @@
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-lodash-subset": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-lodash-subset/-/sp-lodash-subset-1.19.0.tgz",
"integrity": "sha512-jTFdYxU52dYFNbEuIy7p7QPG6ujO5ZaX/pKmxRpXZb1v6JM0l7SzaLMEEyhBeu/HFovlErAM6n5IOccJx31SXA==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-lodash-subset/-/sp-lodash-subset-1.17.3.tgz",
"integrity": "sha512-VmtfG+hcJVxnBcrU4atlOFEUwpRYgJjAj993cg+VacLNYtevf2AVdqkvhRNguXM8smJZdKpMJj1ygtPhdrdBxg==",
"dependencies": {
"@types/lodash": "4.14.117",
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-module-interfaces": {
"version": "1.20.1",
"resolved": "https://registry.npmjs.org/@microsoft/sp-module-interfaces/-/sp-module-interfaces-1.20.1.tgz",
"integrity": "sha512-kV5ipmUyCPL0FgS8uf+OH6Gpu33x8tr7q4eXUQFaG8TaCbrLkCh6F+H1CdcFEPcp7GIC3qdSfI7IhAKG5Cuz4w==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-module-interfaces/-/sp-module-interfaces-1.17.3.tgz",
"integrity": "sha512-oj+C9RA++Gxy6AN5t5DOLRLsvRvGjRIoccbrN1nCbzm/ZPdJFjFoh6EWlEpYlS1S1YMzR/kyfAHpguQtRHiq2A==",
"dependencies": {
"@rushstack/node-core-library": "4.0.2",
"@rushstack/node-core-library": "3.55.2",
"z-schema": "4.2.4"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-odata-types": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-odata-types/-/sp-odata-types-1.19.0.tgz",
"integrity": "sha512-4he2OU/QLcerLGd0RYQ1BOeIRESsM9A14I9g83Db4g+Gs6IrZi8lPSo4dydInL0kPM4U7/z+wRJcw9OGpkTieA==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-odata-types/-/sp-odata-types-1.17.3.tgz",
"integrity": "sha512-fKRaTasv2LXwcgFyPLWDknq82WtHyD842btjO1pg3V57vLc0/Tw4PWNIDZDOWH79RCBE7248957IogNw+TqKkg==",
"dependencies": {
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-office-ui-fabric-core": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-office-ui-fabric-core/-/sp-office-ui-fabric-core-1.19.0.tgz",
"integrity": "sha512-rh54f6JgjZm0qphHk9UIhV1rRSzX3GwDz4joTNw+kSumLCGXVmef5+qrtd6HAFHI/TQCf/FQkgW0a4DFF/qDAA==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-office-ui-fabric-core/-/sp-office-ui-fabric-core-1.17.3.tgz",
"integrity": "sha512-1PE/C0fdbwcxWltrI0kG7Sayl1RIZilsfgU2UjmEIwry4Ltss3YLfAIgp9QOfMsinbvJnj/MN6fXSkFjcXW9fg==",
"dependencies": {
"office-ui-fabric-core": "11.0.1",
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-page-context": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-page-context/-/sp-page-context-1.19.0.tgz",
"integrity": "sha512-fUkwWkEOcRgz6jkLoX18qKLGSLdqyDG1tR8bpXKJloQL6hq6n5RUdq41m3atIGWCLO+UsvkGSgixBMfSGiDGSA==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-page-context/-/sp-page-context-1.17.3.tgz",
"integrity": "sha512-Qrr+GHWS2LVvMpNeIc+YL62ywqKBb2aEhk92ouea7VIXGjJAZA6O3SM45RJCG5dBKgA3oANPkhYyPRhPOR/VbQ==",
"dependencies": {
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-diagnostics": "1.19.0",
"@microsoft/sp-dynamic-data": "1.19.0",
"@microsoft/sp-lodash-subset": "1.19.0",
"@microsoft/sp-odata-types": "1.19.0",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-diagnostics": "1.17.3",
"@microsoft/sp-dynamic-data": "1.17.3",
"@microsoft/sp-lodash-subset": "1.17.3",
"@microsoft/sp-odata-types": "1.17.3",
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-property-pane": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-property-pane/-/sp-property-pane-1.19.0.tgz",
"integrity": "sha512-tBejgARjdkwrlKVEA4sm0c8AcrAdrc99wwRZF4tZHBdAFd/LB7mw7+ZuW71eIYB97efHUdOo5Z9YkrSwRmKd7Q==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-property-pane/-/sp-property-pane-1.17.3.tgz",
"integrity": "sha512-mARwiFXWrj0GL8vNLlhBgp8zyCmuaNlXYul6QKSajkjYp52W5Im3ff9IVWqGxZT0ZinfVkFBXsxtFrxGKP87iw==",
"dependencies": {
"@fluentui/react": "^8.110.12",
"@microsoft/sp-component-base": "1.19.0",
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-diagnostics": "1.19.0",
"@microsoft/sp-dynamic-data": "1.19.0",
"@microsoft/sp-image-helper": "1.19.0",
"@microsoft/sp-lodash-subset": "1.19.0",
"@microsoft/sp-page-context": "1.19.0",
"@fluentui/react": "^8.106.4",
"@microsoft/sp-component-base": "1.17.3",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-diagnostics": "1.17.3",
"@microsoft/sp-dynamic-data": "1.17.3",
"@microsoft/sp-image-helper": "1.17.3",
"@microsoft/sp-lodash-subset": "1.17.3",
"@microsoft/sp-page-context": "1.17.3",
"react": "17.0.1",
"react-dom": "17.0.1",
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
},
"peerDependencies": {
"@types/react": ">=16.9.51 <18.0.0",
@ -10040,36 +10007,36 @@
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-top-actions": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-top-actions/-/sp-top-actions-1.19.0.tgz",
"integrity": "sha512-/1G0J/2sNYK/LXqHnD5h4jitMzatbZRjwT2Qzd4JRxGSujFUe+VYRET90LXdA6lBnDrfZ2MlsVfRkEPrnGyZFQ=="
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-top-actions/-/sp-top-actions-1.17.3.tgz",
"integrity": "sha512-4mcKHak7+OWx3Vi+R3eQth9kUL3VXSIIile77XC8aeMXsBFYb2hUZQsOaR1zmRJ6WOHUGRg08BRXm4LBbCMpDg=="
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/sp-webpart-base": {
"version": "1.19.0",
"resolved": "https://registry.npmjs.org/@microsoft/sp-webpart-base/-/sp-webpart-base-1.19.0.tgz",
"integrity": "sha512-UEWWPDahD4tEAiZVeqCVV0DEU/0LhTgshWDLAeiRvcz5G83JrCN10JCwucYmAzwV3Irisy0DX9nt6C5qWzbvcA==",
"version": "1.17.3",
"resolved": "https://registry.npmjs.org/@microsoft/sp-webpart-base/-/sp-webpart-base-1.17.3.tgz",
"integrity": "sha512-lPyKHVedAU1dNlTO+aRVNCy/Bbs0C+UTjP5aWzEpj8mvzyV01zn0ZGT20msPa0TKxb2ctsfDomqMVZIXq7TUhQ==",
"dependencies": {
"@fluentui/react": "^8.110.12",
"@microsoft/sp-component-base": "1.19.0",
"@microsoft/sp-core-library": "1.19.0",
"@microsoft/sp-diagnostics": "1.19.0",
"@microsoft/sp-dynamic-data": "1.19.0",
"@microsoft/sp-http": "1.19.0",
"@microsoft/sp-http-base": "1.19.0",
"@microsoft/sp-loader": "1.19.0",
"@microsoft/sp-lodash-subset": "1.19.0",
"@microsoft/sp-module-interfaces": "1.20.1",
"@microsoft/sp-page-context": "1.19.0",
"@microsoft/sp-property-pane": "1.19.0",
"@microsoft/sp-top-actions": "1.19.0",
"@microsoft/teams-js-v2": "npm:@microsoft/teams-js@2.12.0",
"@fluentui/react": "^8.106.4",
"@microsoft/sp-component-base": "1.17.3",
"@microsoft/sp-core-library": "1.17.3",
"@microsoft/sp-diagnostics": "1.17.3",
"@microsoft/sp-dynamic-data": "1.17.3",
"@microsoft/sp-http": "1.17.3",
"@microsoft/sp-http-base": "1.17.3",
"@microsoft/sp-loader": "1.17.3",
"@microsoft/sp-lodash-subset": "1.17.3",
"@microsoft/sp-module-interfaces": "1.17.3",
"@microsoft/sp-page-context": "1.17.3",
"@microsoft/sp-property-pane": "1.17.3",
"@microsoft/sp-top-actions": "1.17.3",
"@microsoft/teams-js-v2": "npm:@microsoft/teams-js@2.9.1",
"@types/office-js": "1.0.36",
"react": "17.0.1",
"react-dom": "17.0.1",
"tslib": "2.3.1"
},
"engines": {
"node": ">=18.17.1 <19.0.0"
"node": ">=12.13.0 <13.0.0 || >=14.15.0 <15.0.0 || >=16.13.0 <17.0.0"
},
"peerDependencies": {
"@types/react": ">=16.9.51 <18.0.0",
@ -10105,9 +10072,9 @@
},
"node_modules/@pnp/spfx-property-controls/node_modules/@microsoft/teams-js-v2": {
"name": "@microsoft/teams-js",
"version": "2.12.0",
"resolved": "https://registry.npmjs.org/@microsoft/teams-js/-/teams-js-2.12.0.tgz",
"integrity": "sha512-4gBtIC/Jc4elZ+R9i1LR+4QFwTAPtJ4P1MsCMDafe3HLtFGu/ZQngG9jZkWQ4A/rP4z1wNaDNn39XC+dLfURHQ==",
"version": "2.9.1",
"resolved": "https://registry.npmjs.org/@microsoft/teams-js/-/teams-js-2.9.1.tgz",
"integrity": "sha512-+ch8SVKIkZB4anZF05oEbvcyRcEzIVlRlzh5jSxsJ3HjOrJBd1lgfxqz6pkaAEFsAaTBSLkdziN4qtwVp72Gww==",
"deprecated": "Package no longer supported. Use at your own risk",
"dependencies": {
"debug": "^4.3.3"
@ -10224,23 +10191,24 @@
"integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ=="
},
"node_modules/@pnp/spfx-property-controls/node_modules/@rushstack/loader-raw-script": {
"version": "1.4.37",
"resolved": "https://registry.npmjs.org/@rushstack/loader-raw-script/-/loader-raw-script-1.4.37.tgz",
"integrity": "sha512-pw+e6pLfeqPqmwZgxN/Yxj73AvajjC4NAgiKLdDTd88dYf57er7lRC9jBYz4ETSb/ANjktGNgrJP/4YeLvGF8g==",
"version": "1.3.281",
"resolved": "https://registry.npmjs.org/@rushstack/loader-raw-script/-/loader-raw-script-1.3.281.tgz",
"integrity": "sha512-XEz1ZNTth0bklxK5dF4q+WiVcHFto2hXT4YB+UUkPcnYbQU/z8O1Rh67BrKcmz/8aLjjv3kwuon+4vlkZgappA==",
"dependencies": {
"loader-utils": "1.4.2"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/@rushstack/node-core-library": {
"version": "4.0.2",
"resolved": "https://registry.npmjs.org/@rushstack/node-core-library/-/node-core-library-4.0.2.tgz",
"integrity": "sha512-hyES82QVpkfQMeBMteQUnrhASL/KHPhd7iJ8euduwNJG4mu2GSOKybf0rOEjOm1Wz7CwJEUm9y0yD7jg2C1bfg==",
"version": "3.55.2",
"resolved": "https://registry.npmjs.org/@rushstack/node-core-library/-/node-core-library-3.55.2.tgz",
"integrity": "sha512-SaLe/x/Q/uBVdNFK5V1xXvsVps0y7h1sN7aSJllQyFbugyOaxhNRF25bwEDnicARNEjJw0pk0lYnJQ9Kr6ev0A==",
"dependencies": {
"colors": "~1.2.1",
"fs-extra": "~7.0.1",
"import-lazy": "~4.0.0",
"jju": "~1.4.0",
"resolve": "~1.22.1",
"semver": "~7.5.4",
"semver": "~7.3.0",
"z-schema": "~5.0.2"
},
"peerDependencies": {
@ -10295,6 +10263,11 @@
"resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz",
"integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg=="
},
"node_modules/@pnp/spfx-property-controls/node_modules/adaptivecards": {
"version": "2.11.1",
"resolved": "https://registry.npmjs.org/adaptivecards/-/adaptivecards-2.11.1.tgz",
"integrity": "sha512-dyF23HK+lRMEreexJgHz4y9U5B0ZuGk66N8nhwXRnICyYjq8hE4A6n8rLoV/CNY2QAZ0iRjOIR2J8U7M1CKl8Q=="
},
"node_modules/@pnp/spfx-property-controls/node_modules/commander": {
"version": "2.20.3",
"resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz",
@ -10325,22 +10298,28 @@
"node": ">=4.0.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/lru-cache": {
"version": "6.0.0",
"resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
"integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
"dependencies": {
"yallist": "^4.0.0"
},
"engines": {
"node": ">=10"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/monaco-editor": {
"version": "0.32.1",
"resolved": "https://registry.npmjs.org/monaco-editor/-/monaco-editor-0.32.1.tgz",
"integrity": "sha512-LUt2wsUvQmEi2tfTOK+tjAPvt7eQ+K5C4rZPr6SeuyzjAuAHrIvlUloTcOiGjZW3fn3a/jFQCONrEJbNOaCqbA=="
},
"node_modules/@pnp/spfx-property-controls/node_modules/msal": {
"version": "1.4.17",
"resolved": "https://registry.npmjs.org/msal/-/msal-1.4.17.tgz",
"integrity": "sha512-RjHwP2cCIWQ9iUIk1SziUMb9+jj5mC4OqG2w16E5yig8jySi/TwiFvKlwcjNrPsndph0HtgCtbENnk5julf3yQ==",
"deprecated": "This package is no longer supported. Please use @azure/msal-browser instead.",
"dependencies": {
"tslib": "^1.9.3"
},
"engines": {
"node": ">=0.8.0"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/msal/node_modules/tslib": {
"version": "1.14.1",
"resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz",
"integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg=="
},
"node_modules/@pnp/spfx-property-controls/node_modules/requirejs": {
"version": "2.3.6",
"resolved": "https://registry.npmjs.org/requirejs/-/requirejs-2.3.6.tgz",
@ -10369,20 +10348,6 @@
"url": "https://github.com/sponsors/ljharb"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/semver": {
"version": "7.5.4",
"resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz",
"integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==",
"dependencies": {
"lru-cache": "^6.0.0"
},
"bin": {
"semver": "bin/semver.js"
},
"engines": {
"node": ">=10"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/validator": {
"version": "13.12.0",
"resolved": "https://registry.npmjs.org/validator/-/validator-13.12.0.tgz",
@ -10391,11 +10356,6 @@
"node": ">= 0.10"
}
},
"node_modules/@pnp/spfx-property-controls/node_modules/yallist": {
"version": "4.0.0",
"resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
"integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A=="
},
"node_modules/@pnp/spfx-property-controls/node_modules/z-schema": {
"version": "4.2.4",
"resolved": "https://registry.npmjs.org/z-schema/-/z-schema-4.2.4.tgz",
@ -13870,6 +13830,15 @@
"node": ">=0.10.0"
}
},
"node_modules/@types/hoist-non-react-statics": {
"version": "3.3.5",
"resolved": "https://registry.npmjs.org/@types/hoist-non-react-statics/-/hoist-non-react-statics-3.3.5.tgz",
"integrity": "sha512-SbcrWzkKBw2cdwRTwQAswfpB9g9LJWfjtUeW/jvNwbhC8cpmmNYVePa+ncbUe0rGTQ7G3Ff6mYUN2VMfLVr+Sg==",
"dependencies": {
"@types/react": "*",
"hoist-non-react-statics": "^3.3.0"
}
},
"node_modules/@types/istanbul-lib-coverage": {
"version": "2.0.6",
"resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz",
@ -14041,6 +14010,25 @@
"@types/react": "^17"
}
},
"node_modules/@types/react-sortable-tree": {
"version": "0.3.23",
"resolved": "https://registry.npmjs.org/@types/react-sortable-tree/-/react-sortable-tree-0.3.23.tgz",
"integrity": "sha512-dPyt47T3LiffOsoO3wNUQYIv0eLKvZLJymOv4aApejgVIGYaLy1ifhm23i8NJqxEO99ZF1tqTjzjnHmH6Egw/A==",
"dependencies": {
"@types/react": "*",
"@types/react-virtualized": "*",
"react-dnd": "^11.1.3"
}
},
"node_modules/@types/react-virtualized": {
"version": "9.21.30",
"resolved": "https://registry.npmjs.org/@types/react-virtualized/-/react-virtualized-9.21.30.tgz",
"integrity": "sha512-4l2TFLQ8BCjNDQlvH85tU6gctuZoEdgYzENQyZHpgTHU7hoLzYgPSOALMAeA58LOWua8AzC6wBivPj1lfl6JgQ==",
"dependencies": {
"@types/prop-types": "*",
"@types/react": "*"
}
},
"node_modules/@types/requirejs": {
"version": "2.1.29",
"resolved": "https://registry.npmjs.org/@types/requirejs/-/requirejs-2.1.29.tgz",
@ -17608,6 +17596,14 @@
"readable-stream": "^2.3.5"
}
},
"node_modules/clsx": {
"version": "1.2.1",
"resolved": "https://registry.npmjs.org/clsx/-/clsx-1.2.1.tgz",
"integrity": "sha512-EcR6r5a8bj6pu3ycsa/E/cKVGuTgZJZdsyUYHOksG/UHIiKfjxzRxYJpyVBwYaQeOvghal9fcc4PidlgzugAQg==",
"engines": {
"node": ">=6"
}
},
"node_modules/cmd-extension": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/cmd-extension/-/cmd-extension-1.0.2.tgz",
@ -19095,13 +19091,13 @@
}
},
"node_modules/dnd-core": {
"version": "14.0.1",
"resolved": "https://registry.npmjs.org/dnd-core/-/dnd-core-14.0.1.tgz",
"integrity": "sha512-+PVS2VPTgKFPYWo3vAFEA8WPbTf7/xo43TifH9G8S1KqnrQu0o77A3unrF5yOugy4mIz7K5wAVFHUcha7wsz6A==",
"version": "11.1.3",
"resolved": "https://registry.npmjs.org/dnd-core/-/dnd-core-11.1.3.tgz",
"integrity": "sha512-QugF55dNW+h+vzxVJ/LSJeTeUw9MCJ2cllhmVThVPEtF16ooBkxj0WBE5RB+AceFxMFo1rO6bJKXtqKl+JNnyA==",
"dependencies": {
"@react-dnd/asap": "^4.0.0",
"@react-dnd/invariant": "^2.0.0",
"redux": "^4.1.1"
"redux": "^4.0.4"
}
},
"node_modules/doctrine": {
@ -28457,8 +28453,7 @@
"node_modules/performance-now": {
"version": "2.1.0",
"resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz",
"integrity": "sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow==",
"dev": true
"integrity": "sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow=="
},
"node_modules/picocolors": {
"version": "1.1.0",
@ -29104,6 +29099,14 @@
"node": ">=0.10"
}
},
"node_modules/raf": {
"version": "3.4.1",
"resolved": "https://registry.npmjs.org/raf/-/raf-3.4.1.tgz",
"integrity": "sha512-Sq4CW4QhwOHE8ucn6J34MqtZCeWFP2aQSmrlroYgqAV1PjStIhJXxYuTgUIfkEk7zTLjmIjLmU5q+fbD1NnOJA==",
"dependencies": {
"performance-now": "^2.1.0"
}
},
"node_modules/ramda": {
"version": "0.27.2",
"resolved": "https://registry.npmjs.org/ramda/-/ramda-0.27.2.tgz",
@ -29239,12 +29242,49 @@
"react-dom": "^0.13.0 || ^0.14.0 || ^15.0.1 || ^16.0.0 || ^17.0.0 || ^18.0.0"
}
},
"node_modules/react-dnd-html5-backend": {
"version": "14.1.0",
"resolved": "https://registry.npmjs.org/react-dnd-html5-backend/-/react-dnd-html5-backend-14.1.0.tgz",
"integrity": "sha512-6ONeqEC3XKVf4eVmMTe0oPds+c5B9Foyj8p/ZKLb7kL2qh9COYxiBHv3szd6gztqi/efkmriywLUVlPotqoJyw==",
"node_modules/react-display-name": {
"version": "0.2.5",
"resolved": "https://registry.npmjs.org/react-display-name/-/react-display-name-0.2.5.tgz",
"integrity": "sha512-I+vcaK9t4+kypiSgaiVWAipqHRXYmZIuAiS8vzFvXHHXVigg/sMKwlRgLy6LH2i3rmP+0Vzfl5lFsFRwF1r3pg=="
},
"node_modules/react-dnd": {
"version": "11.1.3",
"resolved": "https://registry.npmjs.org/react-dnd/-/react-dnd-11.1.3.tgz",
"integrity": "sha512-8rtzzT8iwHgdSC89VktwhqdKKtfXaAyC4wiqp0SywpHG12TTLvfOoL6xNEIUWXwIEWu+CFfDn4GZJyynCEuHIQ==",
"dependencies": {
"dnd-core": "14.0.1"
"@react-dnd/shallowequal": "^2.0.0",
"@types/hoist-non-react-statics": "^3.3.1",
"dnd-core": "^11.1.3",
"hoist-non-react-statics": "^3.3.0"
},
"peerDependencies": {
"react": ">= 16.9.0",
"react-dom": ">= 16.9.0"
}
},
"node_modules/react-dnd-html5-backend": {
"version": "11.1.3",
"resolved": "https://registry.npmjs.org/react-dnd-html5-backend/-/react-dnd-html5-backend-11.1.3.tgz",
"integrity": "sha512-/1FjNlJbW/ivkUxlxQd7o3trA5DE33QiRZgxent3zKme8DwF4Nbw3OFVhTRFGaYhHFNL1rZt6Rdj1D78BjnNLw==",
"dependencies": {
"dnd-core": "^11.1.3"
}
},
"node_modules/react-dnd-scrollzone-patch-react-17": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/react-dnd-scrollzone-patch-react-17/-/react-dnd-scrollzone-patch-react-17-1.0.2.tgz",
"integrity": "sha512-Wfhyc/Y/Veim29REBYm8nMmtDB5IwSmPPhXIuabBgsEa1MrVsuOwK9+7LmuP+mGbDOEP/S6G8+5XvDqPlRFK2g==",
"dependencies": {
"hoist-non-react-statics": "^3.1.0",
"lodash.throttle": "^4.0.1",
"prop-types": "^15.5.9",
"raf": "^3.2.0",
"react-display-name": "^0.2.0"
},
"peerDependencies": {
"react": "^17.0.1",
"react-dnd": "^11.1.3",
"react-dom": "^17.0.1"
}
},
"node_modules/react-dom": {
@ -29265,6 +29305,11 @@
"resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz",
"integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w=="
},
"node_modules/react-lifecycles-compat": {
"version": "3.0.4",
"resolved": "https://registry.npmjs.org/react-lifecycles-compat/-/react-lifecycles-compat-3.0.4.tgz",
"integrity": "sha512-fBASbA6LnOU9dOU2eW7aQ8xmYBSXUIWr+UmF9b1efZBazGNO+rcXT/icdKnYm2pTwcRylVUYwW7H1PHfLekVzA=="
},
"node_modules/react-mentions": {
"version": "4.4.10",
"resolved": "https://registry.npmjs.org/react-mentions/-/react-mentions-4.4.10.tgz",
@ -29307,6 +29352,27 @@
"react-dom": "^16 || ^17 || ^18"
}
},
"node_modules/react-sortable-tree-patch-react-17": {
"version": "2.9.0",
"resolved": "https://registry.npmjs.org/react-sortable-tree-patch-react-17/-/react-sortable-tree-patch-react-17-2.9.0.tgz",
"integrity": "sha512-Ngtdbf78OfjqCxLj7+N+K4zM9d1mQ/tfnUsOfICFDzNa5JHg6AjixAj69ijvz0ykEiA9lYop+0Fm4KCOqCdlKA==",
"dependencies": {
"lodash.isequal": "^4.5.0",
"prop-types": "^15.6.1",
"react": "^17.0.0",
"react-dnd": "^11.1.3",
"react-dnd-html5-backend": "^11.1.3",
"react-dnd-scrollzone-patch-react-17": "^1.0.2",
"react-dom": "^17.0.0",
"react-lifecycles-compat": "^3.0.4",
"react-virtualized": "^9.21.2"
},
"peerDependencies": {
"react": "^17.0.0",
"react-dnd": "^11.1.3",
"react-dom": "^17.0.0"
}
},
"node_modules/react-transition-group": {
"version": "4.4.5",
"resolved": "https://registry.npmjs.org/react-transition-group/-/react-transition-group-4.4.5.tgz",
@ -29322,16 +29388,21 @@
"react-dom": ">=16.6.0"
}
},
"node_modules/react-virtuoso": {
"version": "4.10.4",
"resolved": "https://registry.npmjs.org/react-virtuoso/-/react-virtuoso-4.10.4.tgz",
"integrity": "sha512-G/gprhTbK+lzMxoo/iStcZxVEGph/cIhc3WANEpt92RuMw+LiCZOmBfKoeoZOHlm/iyftTrDJhGaTCpxyucnkQ==",
"engines": {
"node": ">=10"
"node_modules/react-virtualized": {
"version": "9.22.5",
"resolved": "https://registry.npmjs.org/react-virtualized/-/react-virtualized-9.22.5.tgz",
"integrity": "sha512-YqQMRzlVANBv1L/7r63OHa2b0ZsAaDp1UhVNEdUaXI8A5u6hTpA5NYtUueLH2rFuY/27mTGIBl7ZhqFKzw18YQ==",
"dependencies": {
"@babel/runtime": "^7.7.2",
"clsx": "^1.0.4",
"dom-helpers": "^5.1.3",
"loose-envify": "^1.4.0",
"prop-types": "^15.7.2",
"react-lifecycles-compat": "^3.0.4"
},
"peerDependencies": {
"react": ">=16 || >=17 || >= 18",
"react-dom": ">=16 || >=17 || >= 18"
"react": "^15.3.0 || ^16.0.0-alpha || ^17.0.0 || ^18.0.0",
"react-dom": "^15.3.0 || ^16.0.0-alpha || ^17.0.0 || ^18.0.0"
}
},
"node_modules/read": {
@ -33030,13 +33101,6 @@
"integrity": "sha512-Ia0sQNrMPXXkqVFt6w6M1n1oKo3NfKs+mvaV811Jwir7vAk9a6PVV9VPYf6X3BU97QiLEmuW3uXH9u87zDFfdw==",
"dev": true
},
"node_modules/undici-types": {
"version": "6.19.8",
"resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.19.8.tgz",
"integrity": "sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==",
"optional": true,
"peer": true
},
"node_modules/union-value": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz",

View File

@ -18,11 +18,11 @@
"@microsoft/sp-office-ui-fabric-core": "1.20.0",
"@microsoft/sp-property-pane": "1.20.0",
"@microsoft/sp-webpart-base": "1.20.0",
"@nosferatu500/react-sortable-tree": "^4.4.0",
"@pnp/graph": "^4.5.0",
"@pnp/sp": "^4.5.0",
"@pnp/spfx-controls-react": "^4.0.0-beta.6059091",
"@pnp/spfx-property-controls": "^3.18",
"@pnp/spfx-property-controls": "^4.0.0-beta.6059131",
"@types/react-sortable-tree": "^0.3.23",
"react": "17.0.1",
"react-dom": "17.0.1",
"tslib": "2.3.1"

View File

@ -1,8 +1,8 @@
import { WebPartContext } from "@microsoft/sp-webpart-base";
import { getGraph } from "../webparts/treeOrgChart/components/pnpjsConfig";
import { ISPFXContext, spfi, SPFI, SPFx as spSPFx } from "@pnp/sp";
import { graphfi, GraphFI, SPFx as graphSPFx } from "@pnp/graph";
import { graphfi, GraphFI } from "@pnp/graph";
import { Caching } from "@pnp/queryable";
@ -20,47 +20,46 @@ export default class GraphService {
private graph: GraphFI;
constructor(private context: WebPartContext) {
this.graph=getGraph(this.context);
this.graph = getGraph(this.context);
}
public async getUser(upn: string): Promise<IGraphUser> {
const graphCache = graphSPFx(this.context).using(Caching({ store: "session"}));
return await graphCache.get().users.getById(upn).select(...graphUserSelect).get() as IGraphUser;;
const graphCache = graphfi(this.graph).using(Caching({ store: "session" }));
return await graphCache.users.getById(upn).select(...graphUserSelect)() as IGraphUser;
}
public async getUserManger(upn: string): Promise<IGraphUser> {
const graphCache = graphSPFx(this.context).using(Caching({ store: "session"}));
const graphCache = graphfi(this.graph).using(Caching({ store: "session" }));
return await graphCache.get().users.getById(upn).manager.select(...graphUserSelect).get() as IGraphUser;
return await graphCache.users.getById(upn).manager.select(...graphUserSelect) as IGraphUser;
}
public async getUserDirectReports(upn: string, excludefilter?: boolean, filter?: string) {
public async getUserDirectReports(upn: string, excludefilter?: boolean, filter?: string): Promise<IGraphUser[]> {
/*
odata filter
"code": "Request_UnsupportedQuery",
"message": "The specified filter to the reference property query is currently not supported.",
*/
const graphCache = graphSPFx(this.context).using();
graphCache.get().users.getById(upn).directReports.select(...graphUserSelect).get() as IGraphUser[];
const directReports = await graphCache.get().users.getById(upn).directReports.select(...graphUserSelect).get() as IGraphUser[];
const graphCache = graphfi(this.graph).using(Caching({ store: "session" }));
//graphCache.users.getById(upn).directReports.select(...graphUserSelect) as IGraphUser[];
const directReports = await graphCache.users.getById(upn).directReports.select(...graphUserSelect)();
if (filter && filter.length > 0) {
if (excludefilter) {
return directReports.filter((user) =>
user.userPrincipalName?.toLowerCase().indexOf(filter.toLowerCase()) === -1
);
return directReports.filter((person) =>
person.userPrincipalName?.toLowerCase().indexOf(filter.toLowerCase()) === -1
) as IGraphUser[];
} else {
return directReports.filter((user) =>
user.userPrincipalName?.toLowerCase().indexOf(filter.toLowerCase()) !== -1
);
)as IGraphUser[];
}
}
return directReports;
return directReports as IGraphUser[];
}
}

View File

@ -1,16 +1,17 @@
/* eslint-disable @typescript-eslint/no-explicit-any */
import {WebPartContext} from "@microsoft/sp-webpart-base";
import { ISPFXContext, spfi, SPFI, SPFx as spSPFx } from "@pnp/sp";
import { graphfi, GraphFI, SPFx as graphSPFx } from "@pnp/graph";
import { spfi, SPFI, } from "@pnp/sp";
import { Caching } from "@pnp/queryable";
import { getSP } from "../webparts/treeOrgChart/components/pnpjsConfig";
export default class SPServices {
private sp: SPFI;
constructor(private context: WebPartContext) {
this.sp = getSP();
this.sp = getSP(this.context);
}
public async getUserProperties(user: string) {
public async getUserProperties(user: string):Promise<any> {
const spCache = spfi(this.sp).using(Caching({ store: "session" }));
return await spCache.profiles.getPropertiesFor(user);
@ -20,8 +21,9 @@ export default class SPServices {
* async GetUserProfileProperty
* user:string
*/
public async getUserProfileProperty(user: string, property: string) {
let UserProperty: any = await sp.profiles.getUserProfilePropertyFor(
public async getUserProfileProperty(user: string, property: string): Promise<string> {
const spCache = spfi(this.sp).using(Caching({ store: "session" }));
const UserProperty: string = await spCache.profiles.getUserProfilePropertyFor(
user,
property
);

View File

@ -7,10 +7,10 @@ import * as strings from 'TreeOrgChartWebPartStrings';
import TreeOrgChart, { TreeOrgChartType } from './components/TreeOrgChart';
import { ITreeOrgChartProps } from './components/ITreeOrgChartProps';
import { PropertyFieldNumber } from '@pnp/spfx-property-controls/lib/PropertyFieldNumber';
import { BaseClientSideWebPart, WebPartContext } from '@microsoft/sp-webpart-base';
import { BaseClientSideWebPart } from '@microsoft/sp-webpart-base';
import { IPropertyPaneConfiguration, PropertyPaneDropdown, PropertyPaneTextField, PropertyPaneToggle} from '@microsoft/sp-property-pane';
import { getSP } from './components/pnpjsConfig';
import { getSP,getGraph } from './components/pnpjsConfig';
export interface ITreeOrgChartWebPartProps {
title: string;
@ -29,7 +29,7 @@ export default class TreeOrgChartWebPart extends BaseClientSideWebPart<ITreeOrgC
public onInit(): Promise<void> {
getSP(this.context);
getgetGraph(this.context);
getGraph(this.context);
//Migration old Config Settings
if (!this.properties.viewType) {
const treetype = this.properties.currentUserTeam ? TreeOrgChartType.MyTeam : TreeOrgChartType.CompanyHierarchy;
@ -136,7 +136,5 @@ export default class TreeOrgChartWebPart extends BaseClientSideWebPart<ITreeOrgC
};
}
}
function getgetGraph(context: WebPartContext) {
throw new Error('Function not implemented.');
}

View File

@ -1,6 +1,6 @@
export interface ITreeData {
title: any;
title: JSX.Element;
expanded ?: boolean;
children ? : ITreeData[]|null;
children ? : ITreeData[];
}

View File

@ -1,5 +1,8 @@
import { ITreeData } from "./ITreeData";
export interface ITreeOrgChartState {
treeData: any;
treeData: ITreeData[];
isLoading: boolean;
// eslint-disable-next-line @typescript-eslint/no-explicit-any
livePersonaCard?: any;
}

View File

@ -0,0 +1,20 @@
import * as React from "react";
import TreeNode from './TreeNode';
interface TreeProps {
data: any[];
renderNode: (node: any) => JSX.Element;
}
import styles from "./TreeNode.module.scss";
const Tree: React.FC<TreeProps> = ({ data, renderNode }) => {
return (
<div className={styles.tree}>
{data.map((node,index) => (
<TreeNode key={index} node={node} first={index===0} last={data.length === index+1} renderNode={renderNode} />
))}
</div>
);
};
export default Tree;

View File

@ -0,0 +1,121 @@
.tree {
margin-left: 40px;
}
.treenode {
position: relative;
margin-left: 20px;
}
.treechildren {
position: relative;
display: flex;
flex-direction: row ;
align-items: stretch;
align-content: stretch;
margin-left: 10px;
}
.nodes {
display: flex;
flex-direction: column;
align-items: flex-start;
position: relative;
}
.collapseButton,
.expandButton {
appearance: none;
border: none;
z-index: 99;
position: absolute;
border-radius: 100%;
box-shadow: 0 0 0 1px #000;
width: 16px;
height: 16px;
padding: 0;
top: 25px;
left: -25px;
transform: translate(-50%, -50%);
cursor: pointer;
background-size: 24px;
height: 20px;
width: 20px;
}
.collapseButton {
background: #fff
url('')
no-repeat center;
}
.expandButton {
background: #fff
url('')
no-repeat center;
}
.line{
width: 10px;
position: relative;
}
.line::after {
content: '';
position: absolute;
background-color: black;
width: 1px;
left: 50%;
top: -10px;
height: calc( 100% - 27px );
}
.middleStyle,
.fistStyle,
.lastStyle
{
height: 100%;
display: inline-block;
position: absolute;
top:-11px;
left:-15px
}
/*
.middleStyle::after,
.fistStyle::after {
content: '';
position: absolute;
background-color: black;
width: 1px;
left: 50%;
top: 0;
height: 65px;
}
*/
/*
.lastStyle::after {
content: '';
position: absolute;
background-color: black;
width: 1px;
left: 50%;
top: 0;
height: 35px;
}
*/
.lastStyle::before ,
.middleStyle::before,
.fistStyle::before {
content: '';
position: absolute;
background-color: black;
width: 25px;
left: -10px;
top: 35px;
height: 1px;
}

View File

@ -0,0 +1,34 @@
import * as React from "react";
interface TreeNodeProps {
node: any;
renderNode: (node: any) => JSX.Element;
first: boolean;
last: boolean;
}
import styles from "./TreeNode.module.scss";
const TreeNode: React.FC<TreeNodeProps> = ({ node, renderNode,first,last }) => {
const [isExpanded, setIsExpanded] = React.useState(true);
return (
<div className={styles.treenode}>
{renderNode(node)}
{node.children && node.children.length > 0 && (<span className={isExpanded ? styles.collapseButton:styles.expandButton} onClick={() => setIsExpanded(!isExpanded)}/>)}
{(!last || !first )&& (<span className={last?styles.lastStyle:first?styles.fistStyle:styles.middleStyle}/>)}
{isExpanded && node.children && node.children.length > 0 && (
<div className={styles.treechildren}>
<div className={styles.line}/>
<div className={styles.nodes}>
{node.children.map((child: any,index:number) => (
<TreeNode key={child.id} node={child} first={index===0} last={node.children && node.children.length === index+1} renderNode={renderNode} />
))}
</div>
</div>
)}
</div>
);
};
export default TreeNode;

View File

@ -6,10 +6,12 @@
margin: 0px auto;
box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.2), 0 25px 50px 0 rgba(0, 0, 0, 0.1);
}
.treeContainer{
height: 450px;
height: auto;
overflow: auto;
}
.row {
@include ms-Grid-row;
@include ms-fontColor-white;
@ -75,3 +77,21 @@
}
}
}
.treeContents {
position: relative;
height: 50px;
border: solid #bbb 1px;
box-shadow: 0 2px 2px -2px;
padding: 0 5px 0 10px;
border-radius: 2px;
min-width: 230px;
flex: 1 0 auto;
display: flex;
align-items: center;
margin-bottom: 20px;
background-color: white;
margin-bottom: 10px;
padding: 0 10px 0 5px;
width: fit-content;
}

View File

@ -1,3 +1,4 @@
/* eslint-disable @typescript-eslint/no-explicit-any */
// SPFx React-tree-Organization-Chart
// Author: João Mendes
// Fev 2019
@ -6,8 +7,6 @@ import * as React from "react";
import styles from "./TreeOrgChart.module.scss";
import { ITreeOrgChartProps } from "./ITreeOrgChartProps";
import { ITreeOrgChartState } from "./ITreeOrgChartState";
import "react-sortable-tree/style.css";
@ -22,7 +21,9 @@ import * as strings from 'TreeOrgChartWebPartStrings';
import GraphServices, { IGraphUser } from "../../../services/GraphService";
import GraphService from "../../../services/GraphService";
import { IconButton, IPersonaSharedProps, Persona, PersonaSize, Spinner, SpinnerSize } from "@fluentui/react";
import SortableTree from "@nosferatu500/react-sortable-tree";
import Tree from "./Tree/Tree";
@ -51,15 +52,18 @@ export default class TreeOrgChart extends React.Component<
isLoading: true
};
}
//
private handleTreeOnChange(treeData:ITreeOrgChartState) {
this.setState({ treeData });
/*
private handleTreeOnChange(treeData:ITreeOrgChartState):void {
this.setState({...treeData });
}
*/
public async componentDidUpdate(
prevProps: ITreeOrgChartProps,
prevState: ITreeOrgChartState
) {
): Promise<void> {
if (
this.props.viewType !== prevProps.viewType ||
this.props.maxLevels !== prevProps.maxLevels ||
@ -72,25 +76,24 @@ export default class TreeOrgChart extends React.Component<
}
}
public async componentDidMount() {
const sharedLibrary = await this._loadSPComponentById(
public async componentDidMount(): Promise<void> {
const sharedLibrary = await this._loadSPComponentById<any>(
LIVE_PERSONA_COMPONENT_ID
);
const livePersonaCard: any = sharedLibrary.LivePersonaCard;
const livePersonaCard: unknown = sharedLibrary.LivePersonaCard;
this.setState({ livePersonaCard: livePersonaCard });
await this.loadOrgchart();
return Promise.resolve();
}
private async _loadSPComponentById(componentId: string): Promise<any> {
private async _loadSPComponentById<TComponent>(componentId: string): Promise<TComponent> {
try {
const component: any = await SPComponentLoader.loadComponentById(
const component: TComponent = await SPComponentLoader.loadComponentById(
componentId
);
return component;
} catch (error) {
Promise.reject(error);
return Promise.reject(error);
}
}
@ -114,15 +117,16 @@ export default class TreeOrgChart extends React.Component<
/*
// Load Organization Chart
*/
public async loadOrgchart() {
public loadOrgchart(): void{
this.setState({ treeData: [], isLoading: true });
this.setState({ treeData: [], isLoading: true }, async () => {
const currentUser = this.props.context.pageContext.user.loginName;
let currentUserProperties = null;
let currentUserProperties = undefined;
this.treeData = [];
// Test if show only my Team or All Organization Chart
switch (this.props.viewType) {
case TreeOrgChartType.CompanyHierarchy:
case TreeOrgChartType.CompanyHierarchy: {
const spcurrentlogin = `i:0#.f|membership|${currentUser}`;
currentUserProperties = await this.SPService.getUserProperties(
spcurrentlogin
@ -132,13 +136,15 @@ export default class TreeOrgChart extends React.Component<
);
if (treeManagers) this.treeData.push(treeManagers);
break;
case TreeOrgChartType.MyTeam:
}
case TreeOrgChartType.MyTeam: {
const myteam = await this.buildMyTeamOrganizationChart(
currentUser
);
if (myteam)
this.treeData = [{ ...myteam }];
break;
}
case TreeOrgChartType.ShowOtherTeam:
if (this.props.teamLeader && this.props.teamLeader.length > 0) {
@ -152,19 +158,24 @@ export default class TreeOrgChart extends React.Component<
}
this.setState({ treeData: this.treeData, isLoading: false });
});
}
/*
Build Organization Chart from currentUser
@parm : currentUserProperties
*/
public async buildOrganizationChart(currentUserProperties: any) {
public async buildOrganizationChart(currentUserProperties: any):Promise<ITreeData | undefined> {
// Get Managers
let treeManagers: ITreeData | null = null;
let treeManagers: ITreeData | undefined = undefined;
if (
currentUserProperties.ExtendedManagers &&
currentUserProperties.ExtendedManagers.length > 0
) {
//get directManager currentUserProperties.ExtendedManagers.length -1
//get orgmanager 0
const upn: string | undefined = this.claimUserToUPN(currentUserProperties.ExtendedManagers[0]);
if (upn) {
treeManagers = await this.getUsers(
@ -201,8 +212,8 @@ export default class TreeOrgChart extends React.Component<
public buildDefaultPersonaCard(user: IGraphUser): JSX.Element {
let spUser: IPersonaSharedProps = {};
let imageInitials: string[] = user.displayName ? user.displayName.split(" ") : [];
const spUser: IPersonaSharedProps = {};
const imageInitials: string[] = user.displayName ? user.displayName.split(" ") : [];
//https://graph.microsoft.com/v1.0/users/${upn}/photo/$value
// Persona Card Properties
spUser.imageUrl = user.userPrincipalName ? `/_layouts/15/userphoto.aspx?size=L&username=${user.userPrincipalName}` : undefined;
@ -223,7 +234,7 @@ export default class TreeOrgChart extends React.Component<
}
private async getUsers(upn: string): Promise<ITreeData | null> {
private async getUsers(upn: string): Promise<ITreeData | undefined> {
const managerUser = await this.GraphService.getUser(upn);
const person = this.buildPersonaCard(managerUser);
if (managerUser.userPrincipalName) {
@ -237,15 +248,14 @@ export default class TreeOrgChart extends React.Component<
}
}
private async getDirectReportsUsers(upn?: string, level: number = 1, expanded: boolean = false): Promise<ITreeData[] | null> {
if (!upn) { return null; }
private async getDirectReportsUsers(upn?: string, level: number = 1, expanded: boolean = false): Promise<ITreeData[] | undefined> {
if (!upn) { return undefined; }
const directReportsUser = await this.GraphService.getUserDirectReports(upn,this.props.excludefilter,this.props.filter);
//this is already level 1
if (directReportsUser && directReportsUser.length > 0) {
return await Promise.all(directReportsUser.map(async (dr) => {
const children = ((level +1) <= this.props.maxLevels) ? await this.getDirectReportsUsers(dr.userPrincipalName, level + 1) : null;
const children = ((level +1) <= this.props.maxLevels) ? await this.getDirectReportsUsers(dr.userPrincipalName, level + 1) : undefined;
return ({
title: this.buildPersonaCard(dr),
expanded: expanded,
@ -254,13 +264,13 @@ export default class TreeOrgChart extends React.Component<
}));
}
return null;
return undefined;
}
//buildTeamLeaderOrganizationChart
private async buildTeamLeaderOrganizationChart(upn: string): Promise<ITreeData | null> {
private async buildTeamLeaderOrganizationChart(upn: string): Promise<ITreeData | undefined> {
const tmpupn: string | undefined = this.claimUserToUPN(upn);
@ -271,7 +281,7 @@ export default class TreeOrgChart extends React.Component<
Build My Team Organization Chart
@parm: currentUserProperties
*/
private async buildMyTeamOrganizationChart(upn: string): Promise<ITreeData | null> {
private async buildMyTeamOrganizationChart(upn: string): Promise<ITreeData | undefined> {
const mymanager = await this.GraphService.getUserManger(upn);
if (mymanager && mymanager.userPrincipalName) {
@ -289,11 +299,7 @@ export default class TreeOrgChart extends React.Component<
selectedTeamleader = this.props.teamLeader;
}
}
const peoplePickerContext: IPeoplePickerContext = {
absoluteUrl: this.props.context.pageContext.web.absoluteUrl,
msGraphClientFactory: this.props.context.msGraphClientFactory,
spHttpClient: this.props.context.spHttpClient
};
return (
<div className={styles.treeOrgChart}>
<WebPartTitle
@ -303,7 +309,7 @@ export default class TreeOrgChart extends React.Component<
/>
{showEditOther && (<div>
<PeoplePicker
context={peoplePickerContext}
context={ this.props.context as any}
titleText={strings.TeamLeaderHeadline}
personSelectionLimit={1}
groupName={""} // Leave this blank in case you want to filter from all users
@ -326,23 +332,26 @@ export default class TreeOrgChart extends React.Component<
resolveDelay={1000} />
</div>)}
{this.state.isLoading ? (
{this.state.isLoading && (
<Spinner
size={SpinnerSize.large}
label="Loading Organization Chart ..."
></Spinner>
) : null}
/>)}
<div className={styles.treeContainer}>
<SortableTree
treeData={this.state.treeData}
onChange={this.handleTreeOnChange.bind(this)}
rowHeight={70}
maxDepth={this.props.maxLevels}
generateNodeProps={rowInfo => {
return !this.props.detailBehavoir ?
({
buttons: [
<IconButton
<Tree data={this.state.treeData} renderNode={this.renderNode.bind(this)} />
</div>
</div>
);
}
private renderNode(node: any):JSX.Element{
console.log(node);
return (<div>
<div className={styles.treeContents}>
<div style={{marginRight:'30px',display:'inline-block'}}>
{node.title}
</div>
{this.props.detailBehavoir &&( <IconButton
disabled={false}
checked={false}
iconProps={{ iconName: "ContactInfo" }}
@ -350,17 +359,11 @@ export default class TreeOrgChart extends React.Component<
ariaLabel={strings.ContactInfoTitle}
onClick={() => {
window.open(
`https://eur.delve.office.com/?p=${rowInfo.node.title.props.tertiaryText}&v=work`
`https://eur.delve.office.com/?p=${node.title.props.tertiaryText}&v=work`
);
}}
/>
]
}) : undefined;
}
}
/>
/>)}
</div>
</div>
);
</div>);
}
}

View File

@ -6,6 +6,7 @@ import { WebPartContext } from "@microsoft/sp-webpart-base";
import { ISPFXContext, spfi, SPFI, SPFx as spSPFx } from "@pnp/sp";
import { graphfi, GraphFI, SPFx as graphSPFx } from "@pnp/graph";
import "@pnp/sp/profiles";
import "@pnp/graph/users";
var _sp: SPFI;