From a2bd2c291f328dcffe998b29fd4c37dab027c555 Mon Sep 17 00:00:00 2001 From: Marius Tobiassen Bungum Date: Mon, 15 Jul 2024 13:58:06 +0200 Subject: [PATCH] :fire: Removed ACL related code --- package-lock.json | 373 ++++++++++--------- package.json | 3 +- src/providers/ReleaseNotesProvider.test.tsx | 304 --------------- src/providers/ReleaseNotesProvider.tsx | 125 ------- src/providers/TutorialStepsProvider.test.tsx | 38 -- src/providers/TutorialStepsProvider.tsx | 83 ----- src/providers/index.ts | 11 +- src/providers/providers.stories.tsx | 14 +- src/utils/releaseNotes.test.ts | 79 ---- src/utils/releaseNotes.ts | 110 ------ 10 files changed, 206 insertions(+), 934 deletions(-) delete mode 100644 src/providers/ReleaseNotesProvider.test.tsx delete mode 100644 src/providers/ReleaseNotesProvider.tsx delete mode 100644 src/providers/TutorialStepsProvider.test.tsx delete mode 100644 src/providers/TutorialStepsProvider.tsx delete mode 100644 src/utils/releaseNotes.test.ts delete mode 100644 src/utils/releaseNotes.ts diff --git a/package-lock.json b/package-lock.json index 7b1389d..bc780df 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "@equinor/subsurface-app-management", - "version": "1.0.5", + "version": "1.0.6", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "@equinor/subsurface-app-management", - "version": "1.0.5", + "version": "1.0.6", "license": "ISC", "dependencies": { "@azure/msal-browser": "3.10.0", @@ -2170,9 +2170,9 @@ } }, "node_modules/@equinor/amplify-components": { - "version": "7.10.5", - "resolved": "https://registry.npmjs.org/@equinor/amplify-components/-/amplify-components-7.10.5.tgz", - "integrity": "sha512-367VFMl/LF0+FmGwy2H7InY+24RNNNzOujIK2X3873bEivYvbCJS9u295PijIsx9P+ufokFBvNo3QQoyHlKxWQ==", + "version": "7.12.9", + "resolved": "https://registry.npmjs.org/@equinor/amplify-components/-/amplify-components-7.12.9.tgz", + "integrity": "sha512-n5XAdD5TMoLp34dTWGSQBY8r+i8f2H5DAQrwq8h5a3q+WAUahQ7RBFrr7Ri7qiepNBLSjEUyoS03oFG5kjEiBQ==", "dev": true, "dependencies": { "@azure/msal-browser": "3.10.0", @@ -3516,9 +3516,9 @@ } }, "node_modules/@microsoft/signalr": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/@microsoft/signalr/-/signalr-8.0.0.tgz", - "integrity": "sha512-K/wS/VmzRWePCGqGh8MU8OWbS1Zvu7DG7LSJS62fBB8rJUXwwj4axQtqrAAwKGUZHQF6CuteuQR9xMsVpM2JNA==", + "version": "8.0.7", + "resolved": "https://registry.npmjs.org/@microsoft/signalr/-/signalr-8.0.7.tgz", + "integrity": "sha512-PHcdMv8v5hJlBkRHAuKG5trGViQEkPYee36LnJQx4xHOQ5LL4X0nEWIxOp5cCtZ7tu+30quz5V3k0b1YNuc6lw==", "dev": true, "dependencies": { "abort-controller": "^3.0.0", @@ -8707,12 +8707,12 @@ } }, "node_modules/@tanstack/react-table": { - "version": "8.17.3", - "resolved": "https://registry.npmjs.org/@tanstack/react-table/-/react-table-8.17.3.tgz", - "integrity": "sha512-5gwg5SvPD3lNAXPuJJz1fOCEZYk9/GeBFH3w/hCgnfyszOIzwkwgp5I7Q4MJtn0WECp84b5STQUDdmvGi8m3nA==", + "version": "8.19.3", + "resolved": "https://registry.npmjs.org/@tanstack/react-table/-/react-table-8.19.3.tgz", + "integrity": "sha512-MtgPZc4y+cCRtU16y1vh1myuyZ2OdkWgMEBzyjYsoMWMicKZGZvcDnub3Zwb6XF2pj9iRMvm1SO1n57lS0vXLw==", "dev": true, "dependencies": { - "@tanstack/table-core": "8.17.3" + "@tanstack/table-core": "8.19.3" }, "engines": { "node": ">=12" @@ -8744,9 +8744,9 @@ } }, "node_modules/@tanstack/table-core": { - "version": "8.17.3", - "resolved": "https://registry.npmjs.org/@tanstack/table-core/-/table-core-8.17.3.tgz", - "integrity": "sha512-mPBodDGVL+fl6d90wUREepHa/7lhsghg2A3vFpakEhrhtbIlgNAZiMr7ccTgak5qbHqF14Fwy+W1yFWQt+WmYQ==", + "version": "8.19.3", + "resolved": "https://registry.npmjs.org/@tanstack/table-core/-/table-core-8.19.3.tgz", + "integrity": "sha512-IqREj9ADoml9zCAouIG/5kCGoyIxPFdqdyoxis9FisXFi5vT+iYfEfLosq4xkU/iDbMcEuAj+X8dWRLvKYDNoQ==", "dev": true, "engines": { "node": ">=12" @@ -8969,35 +8969,35 @@ } }, "node_modules/@tiptap/core": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/core/-/core-2.4.0.tgz", - "integrity": "sha512-YJSahk8pkxpCs8SflCZfTnJpE7IPyUWIylfgXM2DefjRQa5DZ+c6sNY0s/zbxKYFQ6AuHVX40r9pCfcqHChGxQ==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/core/-/core-2.5.0.tgz", + "integrity": "sha512-BEjzVhkyD2LNxiKjEBBbIEpaGE+2I4gclqEIJ4BxrWW+0BgOlYQvqoDn2PF+dAAyXGAxrlwb/+G27tDqRwE+ZQ==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/pm": "^2.0.0" + "@tiptap/pm": "^2.5.0" } }, "node_modules/@tiptap/extension-bold": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-bold/-/extension-bold-2.4.0.tgz", - "integrity": "sha512-csnW6hMDEHoRfxcPRLSqeJn+j35Lgtt1YRiOwn7DlS66sAECGRuoGfCvQSPij0TCDp4VCR9if5Sf8EymhnQumQ==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-bold/-/extension-bold-2.5.0.tgz", + "integrity": "sha512-jCWZUb8GgQmVR96/iLY7mTjGcCXhPHTJOiPqA2ElNdLXmoA2PuyeUcSSU9cyRZ6iV4l1FIZ3lWHTkqtInjHGAQ==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-bubble-menu": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-bubble-menu/-/extension-bubble-menu-2.4.0.tgz", - "integrity": "sha512-s99HmttUtpW3rScWq8rqk4+CGCwergNZbHLTkF6Rp6TSboMwfp+rwL5Q/JkcAG9KGLso1vGyXKbt1xHOvm8zMw==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-bubble-menu/-/extension-bubble-menu-2.5.0.tgz", + "integrity": "sha512-TDFtA8C6rxujB8z1aZA7XN8SG0qyZc1mx8rGYJjBWhoRisOeVZ5YHkEUsOrO3lpR6d1Gs+Pi8ygvN36q9KzSCg==", "dev": true, "dependencies": { "tippy.js": "^6.3.7" @@ -9007,97 +9007,97 @@ "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/pm": "^2.0.0" + "@tiptap/core": "^2.5.0", + "@tiptap/pm": "^2.5.0" } }, "node_modules/@tiptap/extension-bullet-list": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-bullet-list/-/extension-bullet-list-2.4.0.tgz", - "integrity": "sha512-9S5DLIvFRBoExvmZ+/ErpTvs4Wf1yOEs8WXlKYUCcZssK7brTFj99XDwpHFA29HKDwma5q9UHhr2OB2o0JYAdw==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-bullet-list/-/extension-bullet-list-2.5.0.tgz", + "integrity": "sha512-p1zqMWHP40+tlQKVqcISSB1UUlGAL3q+TdDWgmyVTKAcF1pa/+CeqqLB1tuS01kf99Otxn5xDavr1ADlyBhezg==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-code-block": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-code-block/-/extension-code-block-2.4.0.tgz", - "integrity": "sha512-QWGdv1D56TBGbbJSj2cIiXGJEKguPiAl9ONzJ/Ql1ZksiQsYwx0YHriXX6TOC//T4VIf6NSClHEtwtxWBQ/Csg==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-code-block/-/extension-code-block-2.5.0.tgz", + "integrity": "sha512-pcGCXLpMDsDT+tII8ZPpR9uEz67Y3l5TEpizis2CWe8vq2nXnoucU7rG0uNox8s1OUnel6v3183zBRq2O28nxg==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/pm": "^2.0.0" + "@tiptap/core": "^2.5.0", + "@tiptap/pm": "^2.5.0" } }, "node_modules/@tiptap/extension-code-block-lowlight": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-code-block-lowlight/-/extension-code-block-lowlight-2.4.0.tgz", - "integrity": "sha512-j0SdFq66A97Cn7bQOMqFYBaYsmOltZZ6o4uDZH6fdTvEFbfXTdtTYs2awsNSbW+w/DtivKZCvAX1FRLR3/g/5A==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-code-block-lowlight/-/extension-code-block-lowlight-2.5.0.tgz", + "integrity": "sha512-klk0otE7iVOWsztExAiLZNitF8fmD1p17YaIQ9N5eTMpwG7Uburr4/Uz0Q2cTglRm9Ps6AyokloayLezkjvMug==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/extension-code-block": "^2.0.0", - "@tiptap/pm": "^2.0.0" + "@tiptap/core": "^2.5.0", + "@tiptap/extension-code-block": "^2.5.0", + "@tiptap/pm": "^2.5.0" } }, "node_modules/@tiptap/extension-color": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-color/-/extension-color-2.4.0.tgz", - "integrity": "sha512-aVuqGtzTIZO93niADdu+Hx8g03X0pS7wjrJcCcYkkDEbC/siC03zlxKZIYBW1Jiabe99Z7/s2KdtLoK6DW2A2g==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-color/-/extension-color-2.5.0.tgz", + "integrity": "sha512-N5K6VdkXPDijdhYA8nv4DdM6yhzo/gEywhF2nL9O1yj4g8FO0UN7oVAUVPsike0XOrteUaBfeE2m8zH69r5RxQ==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/extension-text-style": "^2.0.0" + "@tiptap/core": "^2.5.0", + "@tiptap/extension-text-style": "^2.5.0" } }, "node_modules/@tiptap/extension-document": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-document/-/extension-document-2.4.0.tgz", - "integrity": "sha512-3jRodQJZDGbXlRPERaloS+IERg/VwzpC1IO6YSJR9jVIsBO6xC29P3cKTQlg1XO7p6ZH/0ksK73VC5BzzTwoHg==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-document/-/extension-document-2.5.0.tgz", + "integrity": "sha512-deaJhDE2NGvhK5GezWIB45HAnbDdKBNbCFIjtrAjjX9CraPt5CSnGSBJJhdddKWo9tuami8Nh18JhKtgiaf6kA==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-dropcursor": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-dropcursor/-/extension-dropcursor-2.4.0.tgz", - "integrity": "sha512-c46HoG2PEEpSZv5rmS5UX/lJ6/kP1iVO0Ax+6JrNfLEIiDULUoi20NqdjolEa38La2VhWvs+o20OviiTOKEE9g==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-dropcursor/-/extension-dropcursor-2.5.0.tgz", + "integrity": "sha512-njo5oKtXBU//aTb1xmvyprQT48sacn7I6zy0xrMTCbYmpJg517AXUwXv02ChPG3uvtTgh8JLwCUkT7xofJNixQ==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/pm": "^2.0.0" + "@tiptap/core": "^2.5.0", + "@tiptap/pm": "^2.5.0" } }, "node_modules/@tiptap/extension-floating-menu": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-floating-menu/-/extension-floating-menu-2.4.0.tgz", - "integrity": "sha512-vLb9v+htbHhXyty0oaXjT3VC8St4xuGSHWUB9GuAJAQ+NajIO6rBPbLUmm9qM0Eh2zico5mpSD1Qtn5FM6xYzg==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-floating-menu/-/extension-floating-menu-2.5.0.tgz", + "integrity": "sha512-0CeKKQLEkz0na0ABvhQKKI+YI8JIUYSqqY2v5CYsfrBbmOoQlVm+hDYXPwR6M1zckXbTQPGzvZ+2xF3anU2tyg==", "dev": true, "dependencies": { "tippy.js": "^6.3.7" @@ -9107,107 +9107,107 @@ "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/pm": "^2.0.0" + "@tiptap/core": "^2.5.0", + "@tiptap/pm": "^2.5.0" } }, "node_modules/@tiptap/extension-gapcursor": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-gapcursor/-/extension-gapcursor-2.4.0.tgz", - "integrity": "sha512-F4y/0J2lseohkFUw9P2OpKhrJ6dHz69ZScABUvcHxjznJLd6+0Zt7014Lw5PA8/m2d/w0fX8LZQ88pZr4quZPQ==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-gapcursor/-/extension-gapcursor-2.5.0.tgz", + "integrity": "sha512-ADNPUp/uucI762AsmIbcnuy7iA33qtaiE+nYML1bdZQbjkSzqMp2FO8M3yng9RBV+V8aX3mEVF5cnOfjNkv9QQ==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/pm": "^2.0.0" + "@tiptap/core": "^2.5.0", + "@tiptap/pm": "^2.5.0" } }, "node_modules/@tiptap/extension-hard-break": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-hard-break/-/extension-hard-break-2.4.0.tgz", - "integrity": "sha512-3+Z6zxevtHza5IsDBZ4lZqvNR3Kvdqwxq/QKCKu9UhJN1DUjsg/l1Jn2NilSQ3NYkBYh2yJjT8CMo9pQIu776g==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-hard-break/-/extension-hard-break-2.5.0.tgz", + "integrity": "sha512-wncfhaLmyLDT3+3GVo2XwjoCrvXltL5ID9k2xhKVVqj2wuBfG1wZd+OHUt4Vg+HVs8cFrOfImlkM4ib2HfnaFQ==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-heading": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-heading/-/extension-heading-2.4.0.tgz", - "integrity": "sha512-fYkyP/VMo7YHO76YVrUjd95Qeo0cubWn/Spavmwm1gLTHH/q7xMtbod2Z/F0wd6QHnc7+HGhO7XAjjKWDjldaw==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-heading/-/extension-heading-2.5.0.tgz", + "integrity": "sha512-PwxBn3gPeanBFFotmfV3EXk8DTjFP03+knfTyMsjC9aCO/KXiiwFwsVf3AnAqLBJ1YV2JzQ8p5czdPDdDaNQPw==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-highlight": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-highlight/-/extension-highlight-2.4.0.tgz", - "integrity": "sha512-p2I/CaMrs6hzpj/dSw6UNobOWTV38yTjPK+B4ShJQ7IN2u/C82KOTOeFfJoFd9KykmpVOVW3w3nKG3ad0HXPuQ==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-highlight/-/extension-highlight-2.5.0.tgz", + "integrity": "sha512-3MKyYatooHDW4SDR523uCiKBGzttEJnxDr95/JGZGSkPiTAejX2rqjKDqRq9rbGwGMU5W+YJ0NXonbRq52aqFA==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-history": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-history/-/extension-history-2.4.0.tgz", - "integrity": "sha512-gr5qsKAXEVGr1Lyk1598F7drTaEtAxqZiuuSwTCzZzkiwgEQsWMWTWc9F8FlneCEaqe1aIYg6WKWlmYPaFwr0w==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-history/-/extension-history-2.5.0.tgz", + "integrity": "sha512-GIvZBhBYcU0Y/RS7f7A/V7VdmYOCBYiFQpT1rG3S+dDztc0PZLLWKm+lpHML97X4oCzqykSGmSZASlCYY8tD7Q==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/pm": "^2.0.0" + "@tiptap/core": "^2.5.0", + "@tiptap/pm": "^2.5.0" } }, "node_modules/@tiptap/extension-image": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-image/-/extension-image-2.4.0.tgz", - "integrity": "sha512-NIVhRPMO/ONo8OywEd+8zh0Q6Q7EbFHtBxVsvfOKj9KtZkaXQfUO4MzONTyptkvAchTpj9pIzeaEY5fyU87gFA==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-image/-/extension-image-2.5.0.tgz", + "integrity": "sha512-3780Nfr+xSoWAHIs1axYbR3iiSwu9HYo5JUF89MjTsdOmGLL3A/qqNET42Ce1RC1zvlYZuw5YvHFyLfNjxNmqg==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-italic": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-italic/-/extension-italic-2.4.0.tgz", - "integrity": "sha512-aaW/L9q+KNHHK+X73MPloHeIsT191n3VLd3xm6uUcFDnUNvzYJ/q65/1ZicdtCaOLvTutxdrEvhbkrVREX6a8g==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-italic/-/extension-italic-2.5.0.tgz", + "integrity": "sha512-on0a1yyb1/cEoIH2nejMa2TM3aJQSJBLKuiO5OXtR1gPu/fFvgv0qLm2T50IONC+B7Y5x32Pkfig6AEb4qhmYg==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-link": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-link/-/extension-link-2.4.0.tgz", - "integrity": "sha512-r3PjT0bjSKAorHAEBPA0icSMOlqALbxVlWU9vAc+Q3ndzt7ht0CTPNewzFF9kjzARABVt1cblXP/2+c0qGzcsg==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-link/-/extension-link-2.5.0.tgz", + "integrity": "sha512-8y7Cgi9o/Y8FK0AP+d6KxasIIG7or+SjWBVWLe7kIWAXJSMtuUMOrbtauuGbA2We6+GTJr7nql70GMjF4EI4Mg==", "dev": true, "dependencies": { "linkifyjs": "^4.1.0" @@ -9217,172 +9217,172 @@ "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/pm": "^2.0.0" + "@tiptap/core": "^2.5.0", + "@tiptap/pm": "^2.5.0" } }, "node_modules/@tiptap/extension-list-item": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-list-item/-/extension-list-item-2.4.0.tgz", - "integrity": "sha512-reUVUx+2cI2NIAqMZhlJ9uK/+zvRzm1GTmlU2Wvzwc7AwLN4yemj6mBDsmBLEXAKPvitfLh6EkeHaruOGymQtg==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-list-item/-/extension-list-item-2.5.0.tgz", + "integrity": "sha512-BU8s1qc/IZeGaTnrK9w9R6xVONWo5OLUl22yJrFWLatA/6Y/uO/6lqSAA9ox67dU4qOGPosFPAfpreSNsQK6pg==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-ordered-list": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-ordered-list/-/extension-ordered-list-2.4.0.tgz", - "integrity": "sha512-Zo0c9M0aowv+2+jExZiAvhCB83GZMjZsxywmuOrdUbq5EGYKb7q8hDyN3hkrktVHr9UPXdPAYTmLAHztTOHYRA==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-ordered-list/-/extension-ordered-list-2.5.0.tgz", + "integrity": "sha512-i2a208+4AF0gKT7dr/G66jwzMTAtaZHLoF7VbV0TluaOOFmPBMvFsUKgs9ShtizY/hDdQUVp8KAdGDKH0jlnuA==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-paragraph": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-paragraph/-/extension-paragraph-2.4.0.tgz", - "integrity": "sha512-+yse0Ow67IRwcACd9K/CzBcxlpr9OFnmf0x9uqpaWt1eHck1sJnti6jrw5DVVkyEBHDh/cnkkV49gvctT/NyCw==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-paragraph/-/extension-paragraph-2.5.0.tgz", + "integrity": "sha512-UgTx+nm3XgAL5/1ruHtjKn4cPwEcGTEo1ePyvBEn0xzy3RbveW9/r/yc+7jqKvT1B6OYc87dhKbgfqzFfXDrQQ==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-placeholder": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-placeholder/-/extension-placeholder-2.4.0.tgz", - "integrity": "sha512-SmWOjgWpmhFt0BPOnL65abCUH0wS5yksUJgtANn5bQoHF4HFSsyl7ETRmgf0ykxdjc7tzOg31FfpWVH4wzKSYg==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-placeholder/-/extension-placeholder-2.5.0.tgz", + "integrity": "sha512-zG2huxWbc2GutFPdSLczPRojro88V5kFFjiUSBAk5wwio8GyHZX5GjClcYSd7mnMLc9kgv2PLczxu4Ek6xoGeg==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/pm": "^2.0.0" + "@tiptap/core": "^2.5.0", + "@tiptap/pm": "^2.5.0" } }, "node_modules/@tiptap/extension-table": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-table/-/extension-table-2.4.0.tgz", - "integrity": "sha512-ceIUnPSqVCb+qC0XZSgApoG3dL3MRvWrGl1nIMxEqPgMsD/MP6MsYV1Lx/GmtdUlEEsV1624cGTBiRzeCuWkZA==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-table/-/extension-table-2.5.0.tgz", + "integrity": "sha512-bHOj21O7io3+T8IqGNpPGZxsfL4R8mLE7ZLXFiBKNSOGYm2J1B+m+MtT4yQiOzyNz/AIhdU20Vc7Z3istIuE1g==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/pm": "^2.0.0" + "@tiptap/core": "^2.5.0", + "@tiptap/pm": "^2.5.0" } }, "node_modules/@tiptap/extension-table-cell": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-table-cell/-/extension-table-cell-2.4.0.tgz", - "integrity": "sha512-zylResMWLvV17Z6+GEDjvvl+YpJqJhNMyJsZPZNx/72OcNCDN3p2d6RGFwhpnCpdzZDD6LGaIgWaTj9oeg53SA==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-table-cell/-/extension-table-cell-2.5.0.tgz", + "integrity": "sha512-urlXpVDWTvYBI1nfied8TYRNHlaKQTEVa32U10Mf4lBCvEVxZ0TD0hFTx6CwZaJE9nNgc/H6aVO1gAWGEuJmag==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-table-header": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-table-header/-/extension-table-header-2.4.0.tgz", - "integrity": "sha512-FZCOyJHSFsMTCfBh49J1DlwgpUIM5Ivpr57Za8FVvUkk8RKUIOKpNsZqxE+Wrw+2Bvy5H4X7Azb588x0NDqfOQ==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-table-header/-/extension-table-header-2.5.0.tgz", + "integrity": "sha512-kjlcUbGKMfjIP8A8uHpsXLHcYaaaWM8z9zQPHUz5mf3DeFcSPGwj028dIyPtNw3BWV2vobwLluLLf4skiiPQMg==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-table-row": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-table-row/-/extension-table-row-2.4.0.tgz", - "integrity": "sha512-K4FDI4YzyLWZbhIZYYL15uqs6M3QsPZGTpTdkSaxcKMLholcskDSHhJmySxnrjI0+JNAtyIiqlWBfA1/9Zyhng==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-table-row/-/extension-table-row-2.5.0.tgz", + "integrity": "sha512-VUdi8Juu+cHcXIsQUYug2M9zcqkxM5/+hho27RIaQiAdUFFCGn4YUwBUu83TTnVThd7Tvx0n1hXC2xc1XZsiMg==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-text": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-text/-/extension-text-2.4.0.tgz", - "integrity": "sha512-LV0bvE+VowE8IgLca7pM8ll7quNH+AgEHRbSrsI3SHKDCYB9gTHMjWaAkgkUVaO1u0IfCrjnCLym/PqFKa+vvg==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-text/-/extension-text-2.5.0.tgz", + "integrity": "sha512-aMY3mhHOk+ihMu4rfn7VVs8MI6uLsCPEUHVJdDlraWkpjiU98uNADKsIc0uYXX7KHSqJWphTiRiC1m+ucgPnYQ==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-text-align": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-text-align/-/extension-text-align-2.4.0.tgz", - "integrity": "sha512-wpRe2OiLXTK4kTy4RZEPnPjFbK16kYHPAx1552hLXrOdyxbS7Sdbo+w4x7aGLLZZqZdudCFfkdtnqrc7PDVZdA==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-text-align/-/extension-text-align-2.5.0.tgz", + "integrity": "sha512-0lPEDQ0VXeg5GoB5Umn8iFaUFMIFVns7d35Y38E1tpj5hopfXLYbXcL528DqHaCM5CD74flEwBFM3p/oYFHEAQ==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-text-style": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-text-style/-/extension-text-style-2.4.0.tgz", - "integrity": "sha512-H0uPWeZ4sXz3o836TDWnpd38qClqzEM2d6QJ9TK+cQ1vE5Gp8wQ5W4fwUV1KAHzpJKE/15+BXBjLyVYQdmXDaQ==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-text-style/-/extension-text-style-2.5.0.tgz", + "integrity": "sha512-k90SeSzMYm7Au+mpyeeVDFotBIg4tEgusejQbpeFLv/atSXgOBwqXkCzHxY0TEtR9/+6mHMgW3QLXBDSogwB4A==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/extension-typography": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/extension-typography/-/extension-typography-2.4.0.tgz", - "integrity": "sha512-RuGenfdPA6ggu5IVLdcIdhGCdRlwSvWp0lETySM3PILE6fxCrxTD54m3pxpY0Q1cg+F71YDUHdSmSipQTwQnsQ==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/extension-typography/-/extension-typography-2.5.0.tgz", + "integrity": "sha512-Ik7ahzA9I1k2b/gxW+28JaRGhc/sKpK6qgl9iJ4qnzeXr4Lv9YxgSeerYZdoLvF5FqzHOmiNSMONygffWe7msQ==", "dev": true, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0" + "@tiptap/core": "^2.5.0" } }, "node_modules/@tiptap/pm": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/pm/-/pm-2.4.0.tgz", - "integrity": "sha512-B1HMEqGS4MzIVXnpgRZDLm30mxDWj51LkBT/if1XD+hj5gm8B9Q0c84bhvODX6KIs+c6z+zsY9VkVu8w9Yfgxg==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/pm/-/pm-2.5.0.tgz", + "integrity": "sha512-FMwvDiJPTlCVkLXDhhnZ8ySDpRuL/3wFJIm5gSlUPKT8mq5/V5J2fLSL+QYsOxbWsHW8ZjpfWx/VCqBVxSinig==", "dev": true, "dependencies": { "prosemirror-changeset": "^2.2.1", @@ -9390,19 +9390,19 @@ "prosemirror-commands": "^1.5.2", "prosemirror-dropcursor": "^1.8.1", "prosemirror-gapcursor": "^1.3.2", - "prosemirror-history": "^1.3.2", - "prosemirror-inputrules": "^1.3.0", + "prosemirror-history": "^1.4.0", + "prosemirror-inputrules": "^1.4.0", "prosemirror-keymap": "^1.2.2", - "prosemirror-markdown": "^1.12.0", + "prosemirror-markdown": "^1.13.0", "prosemirror-menu": "^1.2.4", - "prosemirror-model": "^1.19.4", + "prosemirror-model": "^1.21.3", "prosemirror-schema-basic": "^1.2.2", - "prosemirror-schema-list": "^1.3.0", + "prosemirror-schema-list": "^1.4.0", "prosemirror-state": "^1.4.3", - "prosemirror-tables": "^1.3.5", - "prosemirror-trailing-node": "^2.0.7", - "prosemirror-transform": "^1.8.0", - "prosemirror-view": "^1.32.7" + "prosemirror-tables": "^1.3.7", + "prosemirror-trailing-node": "^2.0.8", + "prosemirror-transform": "^1.9.0", + "prosemirror-view": "^1.33.7" }, "funding": { "type": "github", @@ -9410,21 +9410,23 @@ } }, "node_modules/@tiptap/react": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@tiptap/react/-/react-2.4.0.tgz", - "integrity": "sha512-baxnIr6Dy+5iGagOEIKFeHzdl1ZRa6Cg+SJ3GDL/BVLpO6KiCM3Mm5ymB726UKP1w7icrBiQD2fGY3Bx8KaiSA==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/@tiptap/react/-/react-2.5.0.tgz", + "integrity": "sha512-wZ8LD6zM+OudrGpLhYzLMCjSmxT7jm6lflIuynxdsHPHHgOohbgyVCZhxdLyPpd+IhiWC5YRJSOen6X+wxWb0Q==", "dev": true, "dependencies": { - "@tiptap/extension-bubble-menu": "^2.4.0", - "@tiptap/extension-floating-menu": "^2.4.0" + "@tiptap/extension-bubble-menu": "^2.5.0", + "@tiptap/extension-floating-menu": "^2.5.0", + "@types/use-sync-external-store": "^0.0.6", + "use-sync-external-store": "^1.2.2" }, "funding": { "type": "github", "url": "https://github.com/sponsors/ueberdosis" }, "peerDependencies": { - "@tiptap/core": "^2.0.0", - "@tiptap/pm": "^2.0.0", + "@tiptap/core": "^2.5.0", + "@tiptap/pm": "^2.5.0", "react": "^17.0.0 || ^18.0.0", "react-dom": "^17.0.0 || ^18.0.0" } @@ -9835,6 +9837,12 @@ "integrity": "sha512-dqId9J8K/vGi5Zr7oo212BGii5m3q5Hxlkwy3WpYuKPklmBEvsbMYYyLxAQpSffdLl/gdW0XUpKWFvYmyoWCoQ==", "dev": true }, + "node_modules/@types/use-sync-external-store": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/@types/use-sync-external-store/-/use-sync-external-store-0.0.6.tgz", + "integrity": "sha512-zFDAD+tlpf2r4asuHEj0XH6pY6i0g5NeAHPn+15wk3BV6JA69eERFXC1gyGThDkVa1zCyKr5jox1+2LbV/AMLg==", + "dev": true + }, "node_modules/@types/uuid": { "version": "9.0.8", "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-9.0.8.tgz", @@ -22130,9 +22138,9 @@ } }, "node_modules/prosemirror-history": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/prosemirror-history/-/prosemirror-history-1.4.0.tgz", - "integrity": "sha512-UUiGzDVcqo1lovOPdi9YxxUps3oBFWAIYkXLu3Ot+JPv1qzVogRbcizxK3LhHmtaUxclohgiOVesRw5QSlMnbQ==", + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/prosemirror-history/-/prosemirror-history-1.4.1.tgz", + "integrity": "sha512-2JZD8z2JviJrboD9cPuX/Sv/1ChFng+xh2tChQ2X4bB2HeK+rra/bmJ3xGntCcjhOqIzSDG6Id7e8RJ9QPXLEQ==", "dev": true, "dependencies": { "prosemirror-state": "^1.2.2", @@ -22184,27 +22192,27 @@ } }, "node_modules/prosemirror-model": { - "version": "1.21.1", - "resolved": "https://registry.npmjs.org/prosemirror-model/-/prosemirror-model-1.21.1.tgz", - "integrity": "sha512-IVBAuMqOfltTr7yPypwpfdGT+6rGAteVOw2FO6GEvCGGa1ZwxLseqC1Eax/EChDvG/xGquB2d/hLdgh3THpsYg==", + "version": "1.22.1", + "resolved": "https://registry.npmjs.org/prosemirror-model/-/prosemirror-model-1.22.1.tgz", + "integrity": "sha512-gMrxal+F3higDFxCkBK5iQXckRVYvIu/3dopERJ6b20xfwZ9cbYvQvuldqaN+v/XytNPGyURYUpUU23kBRxWCQ==", "dev": true, "dependencies": { "orderedmap": "^2.0.0" } }, "node_modules/prosemirror-schema-basic": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/prosemirror-schema-basic/-/prosemirror-schema-basic-1.2.2.tgz", - "integrity": "sha512-/dT4JFEGyO7QnNTe9UaKUhjDXbTNkiWTq/N4VpKaF79bBjSExVV2NXmJpcM7z/gD7mbqNjxbmWW5nf1iNSSGnw==", + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/prosemirror-schema-basic/-/prosemirror-schema-basic-1.2.3.tgz", + "integrity": "sha512-h+H0OQwZVqMon1PNn0AG9cTfx513zgIG2DY00eJ00Yvgb3UD+GQ/VlWW5rcaxacpCGT1Yx8nuhwXk4+QbXUfJA==", "dev": true, "dependencies": { "prosemirror-model": "^1.19.0" } }, "node_modules/prosemirror-schema-list": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/prosemirror-schema-list/-/prosemirror-schema-list-1.4.0.tgz", - "integrity": "sha512-nZOIq/AkBSzCENxUyLm5ltWE53e2PLk65ghMN8qLQptOmDVixZlPqtMeQdiNw0odL9vNpalEjl3upgRkuJ/Jyw==", + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/prosemirror-schema-list/-/prosemirror-schema-list-1.4.1.tgz", + "integrity": "sha512-jbDyaP/6AFfDfu70VzySsD75Om2t3sXTOdl5+31Wlxlg62td1haUpty/ybajSfJ1pkGadlOfwQq9kgW5IMo1Rg==", "dev": true, "dependencies": { "prosemirror-model": "^1.0.0", @@ -25835,6 +25843,15 @@ } } }, + "node_modules/use-sync-external-store": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/use-sync-external-store/-/use-sync-external-store-1.2.2.tgz", + "integrity": "sha512-PElTlVMwpblvbNqQ82d2n6RjStvdSoNe9FG28kNfz3WiXilJm4DdNkEzRhCZuIDwY8U08WVihhGR5iRqAwfDiw==", + "dev": true, + "peerDependencies": { + "react": "^16.8.0 || ^17.0.0 || ^18.0.0" + } + }, "node_modules/util": { "version": "0.12.5", "resolved": "https://registry.npmjs.org/util/-/util-0.12.5.tgz", diff --git a/package.json b/package.json index e555562..fe90d50 100644 --- a/package.json +++ b/package.json @@ -1,9 +1,10 @@ { "name": "@equinor/subsurface-app-management", - "version": "1.0.5", + "version": "1.0.6", "description": "React Typescript components/hooks to communicate with equinor/sam", "main": "dist/index.js", "types": "dist/index.d.ts", + "type": "module", "author": "Amplify Team", "license": "ISC", "homepage": "https://github.com/equinor/subsurface-app-management#readme", diff --git a/src/providers/ReleaseNotesProvider.test.tsx b/src/providers/ReleaseNotesProvider.test.tsx deleted file mode 100644 index 34ab2c9..0000000 --- a/src/providers/ReleaseNotesProvider.test.tsx +++ /dev/null @@ -1,304 +0,0 @@ -import { FC, ReactNode } from 'react'; - -import { QueryClient, QueryClientProvider } from '@tanstack/react-query'; - -import { act, renderHook, waitFor } from '../tests/test-utils'; -import { ReleaseNoteType } from '../types/ReleaseNotes'; -import ReleaseNotesProvider, { useReleaseNotes } from './ReleaseNotesProvider'; -import { CancelablePromise } from 'src/api'; - -const releaseNotes = [ - { - releaseId: '123456-1233', - applicationName: 'ASDF', - version: '12.2.2', - title: 'Lorem ipsum', - body: '

Release notes body text

', - tags: [ReleaseNoteType.FEATURE, ReleaseNoteType.IMPROVEMENT], - createdDate: '2023-05-31T22:00:00.000Z', - }, - { - releaseId: '1234dqw6-1233', - applicationName: 'ASDF', - version: '12.2.3', - title: 'Lorem ipsum', - body: '

Release2 notes body text

', - tags: [], - createdDate: '2020-05-31T22:00:00.000Z', - }, - { - releaseId: '1234dqw6-1233', - applicationName: 'ASDF', - version: '12.2.3', - title: 'Lorem ipsum', - body: '

Release2 notes body text qWert

', - tags: [ReleaseNoteType.IMPROVEMENT], - createdDate: '2022-05-31T22:00:00.000Z', - }, -]; - -const monthAndYears = [ - { - label: '2023', - months: [ - { - label: 'June 2023', - value: new Date('2023-05-31T22:00:00.000Z'), - }, - ], - value: '2023', - }, -]; -const mockServiceHasError = false; - -vi.mock('src/api/services/ReleaseNotesService', () => { - class ReleaseNotesService { - public static getReleasenoteList(): CancelablePromise { - return new CancelablePromise((resolve, reject) => { - setTimeout(() => { - if (mockServiceHasError) { - reject('error release notes'); - } else { - resolve(releaseNotes); - } - }, 200); - }); - } - } - return { ReleaseNotesService }; -}); - -interface WrapperProp { - children: ReactNode; -} - -const Wrappers: FC = ({ children }) => { - const queryClient = new QueryClient(); - return ( - - {children} - - ); -}; - -describe('Release notes provider', () => { - test('should not return any data when enabled is set to false', () => { - const wrapper: FC = ({ children }) => { - const queryClient = new QueryClient(); - return ( - - - {children} - - - ); - }; - const { result } = renderHook(() => useReleaseNotes(), { - wrapper, - }); - - expect(result.current.filteredData.length).toEqual(0); - expect(result.current.releaseNotesYears.length).toEqual(0); - }); - test('should correctly return filtered data', async () => { - const { result } = renderHook(() => useReleaseNotes(), { - wrapper: Wrappers, - }); - - // TODO: improve on this hack; To use expect as a way to ensure that data is populated so that we can check more specifically what we expect - await waitFor( - () => { - return expect(result.current.filteredData.length).toBe(3); - }, - { timeout: 550 } - ); - expect(result.current.filteredData).toStrictEqual(releaseNotes); - }); - - test('calling toggle should change open', async () => { - const { result } = renderHook(() => useReleaseNotes(), { - wrapper: Wrappers, - }); - - result.current.toggle(); - - await waitFor( - () => { - return expect(result.current.open).toBe(true); - }, - { timeout: 550 } - ); - }); - - test('should use setSearch to populate search variable', async () => { - const { result } = renderHook(() => useReleaseNotes(), { - wrapper: Wrappers, - }); - - // TODO: improve on this hack; To use expect as a way to ensure that data is populated so that we can check more specifically what we expect - await waitFor( - () => { - return expect(result.current.filteredData.length).toBe(3); - }, - { timeout: 550 } - ); - expect(result.current.search.filterValues).toBe(undefined); - expect(result.current.search.searchValue).toBe(undefined); - expect(result.current.search.sortValue).toBe(undefined); - - act(() => { - result.current.setSearch({ - filterValues: {}, - searchValue: '', - sortValue: { label: '', value: '' }, - }); - }); - await waitFor( - () => { - return expect(result.current.filteredData.length).toBe(3); - }, - { timeout: 550 } - ); - expect(result.current.search.filterValues).toStrictEqual({}); - expect(result.current.search.searchValue).toBe(''); - expect(result.current.search.sortValue).toStrictEqual({ - label: '', - value: '', - }); - }); - - test('should correctly return extracted month and year from data', async () => { - const { result } = renderHook(() => useReleaseNotes(), { - wrapper: Wrappers, - }); - - // TODO: improve on this hack; To use expect as a way to ensure that data is populated so that we can check more specifically what we expect - await waitFor( - () => { - return expect(result.current.filteredData.length).toBe(3); - }, - { timeout: 550 } - ); - expect(monthAndYears).toBeDefined(); - }); - - test('should return an empty list when searchValue has a term which does not match anything in release notes', async () => { - const { result } = renderHook(() => useReleaseNotes(), { - wrapper: Wrappers, - }); - - act(() => { - result.current.setSearch({ - filterValues: undefined, - searchValue: 'qwerty qwert', - sortValue: undefined, - }); - }); - - // TODO: improve on this hack; To use expect as a way to ensure that data is populated so that we can check more specifically what we expect - await waitFor( - () => { - return expect(result.current.filteredData.length).toBe(0); - }, - { timeout: 550 } - ); - expect(result.current.filteredData).toStrictEqual([]); - }); - - test('should return one item when searchValue has a term which matches to something that release note contains', async () => { - const { result } = renderHook(() => useReleaseNotes(), { - wrapper: Wrappers, - }); - - act(() => { - result.current.setSearch({ - filterValues: undefined, - searchValue: ' qwert', - sortValue: undefined, - }); - }); - - const expected = [ - { - releaseId: '1234dqw6-1233', - applicationName: 'ASDF', - version: '12.2.3', - title: 'Lorem ipsum', - body: '

Release2 notes body text qWert

', - tags: [ReleaseNoteType.IMPROVEMENT], - createdDate: '2022-05-31T22:00:00.000Z', - }, - ]; - - // TODO: improve on this hack; To use expect as a way to ensure that data is populated so that we can check more specifically what we expect - await waitFor( - () => { - expect(result.current.filteredData.length).toBe(1); - expect(result.current.filteredData).toStrictEqual(expected); - }, - { timeout: 550 } - ); - }); - - test('should return one item filterValues is set to match release notes', async () => { - const { result } = renderHook(() => useReleaseNotes(), { - wrapper: Wrappers, - }); - - act(() => { - result.current.setSearch({ - filterValues: { - Type: [ - { label: ReleaseNoteType.FEATURE, value: ReleaseNoteType.FEATURE }, - ], - }, - searchValue: undefined, - sortValue: undefined, - }); - }); - - // TODO: improve on this hack; To use expect as a way to ensure that data is populated so that we can check more specifically what we expect - await waitFor( - () => { - return expect(result.current.filteredData.length).toBe(1); - }, - { timeout: 550 } - ); - expect(result.current.filteredData).toStrictEqual([releaseNotes[0]]); - }); - - test('should return an empty list when filterValues does not match anything in release notes', async () => { - const { result } = renderHook(() => useReleaseNotes(), { - wrapper: Wrappers, - }); - - act(() => { - result.current.setSearch({ - filterValues: { - Type: [ - { label: ReleaseNoteType.BUG_FIX, value: ReleaseNoteType.BUG_FIX }, - ], - }, - searchValue: undefined, - sortValue: undefined, - }); - }); - - // TODO: improve on this hack; To use expect as a way to ensure that data is populated so that we can check more specifically what we expect - await waitFor( - () => { - return expect(result.current.filteredData.length).toBe(0); - }, - { timeout: 550 } - ); - expect(result.current.filteredData).toStrictEqual([]); - }); - - test("'useReleaseNotes' hook throws error if using outside of context", () => { - // Hides console errors since this test explicitly tests for thrown errors - console.error = vi.fn(); - expect(() => renderHook(() => useReleaseNotes())).toThrow( - 'useReleaseNotes must be used within a ReleaseNotesProvider' - ); - }); -}); diff --git a/src/providers/ReleaseNotesProvider.tsx b/src/providers/ReleaseNotesProvider.tsx deleted file mode 100644 index 5ce497a..0000000 --- a/src/providers/ReleaseNotesProvider.tsx +++ /dev/null @@ -1,125 +0,0 @@ -import { - createContext, - Dispatch, - FC, - ReactNode, - SetStateAction, - useContext, - useMemo, - useState, -} from 'react'; - -import { - Option, - SieveValue, - TableOfContentsItemType, -} from '@equinor/amplify-components'; - -import { ReleaseNote } from 'src/api/models/ReleaseNote'; -import { useReleaseNotesQuery } from 'src/hooks/useReleaseNotesQuery'; -import { - extractDatesFromReleaseNotes, - sortReleaseNotesByDate, -} from 'src/utils/releaseNotes'; - -interface ReleaseNotesContextState { - search: SieveValue; - setSearch: Dispatch>; - selectedReleaseNoteTypes?: Option[]; - open: boolean; - setOpen: (open: boolean) => void; - toggle: () => void; - filteredData: ReleaseNote[]; - releaseNotesYears: TableOfContentsItemType[]; -} - -const defaultSearchState: SieveValue = { - filterValues: undefined, - searchValue: undefined, - sortValue: undefined, -}; - -const ReleaseNotesContext = createContext( - undefined -); - -export const useReleaseNotes = (): ReleaseNotesContextState => { - const context = useContext(ReleaseNotesContext); - if (context === undefined) { - throw new Error( - 'useReleaseNotes must be used within a ReleaseNotesProvider' - ); - } - return context; -}; - -interface ReleaseNotesContextProviderProps { - children: ReactNode; - enabled?: boolean; -} - -const ReleaseNotesProvider: FC = ({ - children, - enabled, -}) => { - const { data } = useReleaseNotesQuery({ enabled }); - const [search, setSearch] = useState(defaultSearchState); - const [open, setOpen] = useState(false); - - const toggle = () => { - setOpen((previous) => !previous); - }; - - const releaseNotesYears = useMemo( - () => extractDatesFromReleaseNotes(data ?? []), - [data] - ); - - const selectedReleaseNoteTypes = search.filterValues?.Type; - - const filteredData = useMemo(() => { - let filteredList = data ?? []; - - if (selectedReleaseNoteTypes && selectedReleaseNoteTypes.length > 0) { - filteredList = filteredList.filter((item) => - item.tags?.some((tag) => - selectedReleaseNoteTypes - .map((option: Option) => option.value) - .includes(tag) - ) - ); - } - - if (search?.searchValue && search?.searchValue?.trim() !== '') { - const searchTerms = search.searchValue.trim().toLowerCase().split(' '); - filteredList = filteredList.filter((item) => { - return Object.values(item) - .join(' ') - .toLowerCase() - .includes(searchTerms.join(' ')); - }); - } - sortReleaseNotesByDate(filteredList); - - return filteredList; - }, [data, search.searchValue, selectedReleaseNoteTypes]); - - const contextValue: ReleaseNotesContextState = { - search, - setSearch, - selectedReleaseNoteTypes, - open, - setOpen, - toggle, - filteredData, - releaseNotesYears, - }; - - return ( - - {children} - - ); -}; - -export default ReleaseNotesProvider; diff --git a/src/providers/TutorialStepsProvider.test.tsx b/src/providers/TutorialStepsProvider.test.tsx deleted file mode 100644 index c1f4d4a..0000000 --- a/src/providers/TutorialStepsProvider.test.tsx +++ /dev/null @@ -1,38 +0,0 @@ -import { ReactElement } from 'react'; - -import { renderHook } from '../tests/test-utils'; -import TutorialStepsProvider, { - useTutorialSteps, -} from './TutorialStepsProvider'; - -const TutorialStepsProviderWithStartOpen = ({ - children, -}: { - children: ReactElement; -}) => { - return {children}; -}; - -test('startOpen = false works as expected', () => { - const { result } = renderHook(() => useTutorialSteps(), { - wrapper: TutorialStepsProvider, - }); - - expect(result.current.showTutorialIntro).toBe(false); -}); - -test('startOpen = true works as expected', () => { - const { result } = renderHook(() => useTutorialSteps(), { - wrapper: TutorialStepsProviderWithStartOpen, - }); - - expect(result.current.showTutorialIntro).toBe(true); -}); - -test("'useTutorialSteps' hook throws error if using outside of context", () => { - // Hides console errors since this test explicitly tests for thrown errors - console.error = vi.fn(); - expect(() => renderHook(() => useTutorialSteps())).toThrow( - 'useTutorialSteps must be used within a TutorialStepsProvider' - ); -}); diff --git a/src/providers/TutorialStepsProvider.tsx b/src/providers/TutorialStepsProvider.tsx deleted file mode 100644 index 8c72373..0000000 --- a/src/providers/TutorialStepsProvider.tsx +++ /dev/null @@ -1,83 +0,0 @@ -import React, { - createContext, - FC, - ReactNode, - useContext, - useEffect, - useState, -} from 'react'; - -const localStorageKey = 'tutorialstepscontext'; - -interface TutorialContextState { - tutorialStep: string; - setTutorialStep: (val: string) => void; - showTutorialIntro: boolean; - setShowTutorialIntro: (val: boolean) => void; -} - -interface TutorialState { - step: string; - showTutorialIntro: boolean; -} - -const getDefaultState = (): TutorialState => { - const localStorageData = localStorage.getItem(localStorageKey); - - if (localStorageData) { - return JSON.parse(localStorageData) as TutorialState; - } - return { step: '', showTutorialIntro: false }; -}; - -const updateLocalStorage = (state: TutorialState) => { - localStorage.setItem(localStorageKey, JSON.stringify(state)); -}; - -const TutorialStepsContext = createContext( - undefined -); - -export const useTutorialSteps = (): TutorialContextState => { - const context = useContext(TutorialStepsContext); - if (context === undefined) { - throw new Error( - 'useTutorialSteps must be used within a TutorialStepsProvider' - ); - } - return context; -}; - -const TutorialStepsProvider: FC<{ - children: ReactNode; - startOpen?: boolean; -}> = ({ children, startOpen = false }) => { - const [tutorialStep, setTutorialStep] = useState( - getDefaultState().step - ); - const [showTutorialIntro, setShowTutorialIntro] = useState( - startOpen ? startOpen : getDefaultState().showTutorialIntro - ); - - useEffect(() => { - updateLocalStorage({ - step: tutorialStep, - showTutorialIntro: showTutorialIntro, - }); - }, [showTutorialIntro, tutorialStep]); - - return ( - - {children} - - ); -}; - -export default TutorialStepsProvider; diff --git a/src/providers/index.ts b/src/providers/index.ts index b7dbd4d..bc212f9 100644 --- a/src/providers/index.ts +++ b/src/providers/index.ts @@ -1,12 +1,5 @@ import AuthProvider from './AuthProvider/AuthProvider'; import TutorialProvider from './TutorialProvider/TutorialProvider'; import FeatureToggleProvider from './FeatureToggleProvider'; -import ReleaseNotesProvider from './ReleaseNotesProvider'; -import TutorialStepsProvider from './TutorialStepsProvider'; -export { - AuthProvider, - FeatureToggleProvider, - TutorialProvider, - TutorialStepsProvider, - ReleaseNotesProvider, -}; + +export { AuthProvider, FeatureToggleProvider, TutorialProvider }; diff --git a/src/providers/providers.stories.tsx b/src/providers/providers.stories.tsx index b395988..4bfc4a9 100644 --- a/src/providers/providers.stories.tsx +++ b/src/providers/providers.stories.tsx @@ -12,13 +12,6 @@ const providersList = [ unauthorizedComponent={componentToShowWhenUnauthorized}> {children} `, - }, - { - name: 'ReleaseNotesProvider', - body: 'Provider to make ReleaseNotes work', - code: ` - {children} -`, }, { name: 'TutorialStepsProvider', @@ -27,6 +20,13 @@ const providersList = [ {children} `, }, + { + name: 'FeatureToggleProvider', + body: 'Provider needed to use feature toggle hook', + code: ` + {children} +`, + }, ]; const Container = styled.div` diff --git a/src/utils/releaseNotes.test.ts b/src/utils/releaseNotes.test.ts deleted file mode 100644 index f6ee1f7..0000000 --- a/src/utils/releaseNotes.test.ts +++ /dev/null @@ -1,79 +0,0 @@ -import { - extractDatesFromReleaseNotes, - monthToString, - monthValueToString, - sortReleaseNotesByDate, - yearValueToString, -} from './releaseNotes'; - -const dateObject = new Date('2023-06-29T10:50:22.8210567+00:00'); -const dates = [ - { createdDate: '2022-06-29T10:50:22.8210567+00:00' }, - { createdDate: '2022-01-13T10:50:22.8210567+00:00' }, - { createdDate: '2022-07-20T10:50:22.8210567+00:00' }, - { createdDate: '2023-06-29T10:50:22.8210567+00:00' }, - { createdDate: '2022-05-29T10:50:22.8210567+00:00' }, -]; - -const notes = [ - { createdDate: '2023-06-29' }, - { createdDate: '2020-06-29' }, - { createdDate: '2022-06-29' }, - { createdDate: '2023-01-17' }, - { createdDate: '2022-08-31' }, - { createdDate: undefined }, - { createdDate: undefined }, -]; - -describe('release notes utils', () => { - test('extract years and months from list containing createdDate attribute', () => { - const expectedYear = '2023'; - const expectedMonth = 'June'; - const actual = extractDatesFromReleaseNotes(dates); - expect(actual[0].label).toEqual(expectedYear); - expect((actual[0].children ?? [])[0].label).toEqual(expectedMonth); - }); - - test('should sort years and months in page menu descending', () => { - const expectedYearOrder = ['2023', '2022']; - const expectedMonthOrder = ['July', 'June', 'May', 'January']; - const actual = extractDatesFromReleaseNotes(dates); - - expect(actual[0].label).toEqual(expectedYearOrder[0]); - expect(actual[1].label).toEqual(expectedYearOrder[1]); - expect((actual[1].children ?? [])[0].label).toEqual(expectedMonthOrder[0]); - expect((actual[1].children ?? [])[1].label).toEqual(expectedMonthOrder[1]); - expect((actual[1].children ?? [])[2].label).toEqual(expectedMonthOrder[2]); - expect((actual[1].children ?? [])[3].label).toEqual(expectedMonthOrder[3]); - }); - - test('transform date to month string', () => { - const expectedYear = 'June'; - const actual = monthToString(dateObject); - expect(actual).toEqual(expectedYear); - }); - test('transform date to a string in the format of month_year: year2023--June', () => { - const expectedYear = 'year2023--June'; - const actual = monthValueToString(dateObject); - expect(actual).toEqual(expectedYear); - }); - test('transform date to string formatted with a year_ prefix to the year: year2023', () => { - const expectedYear = 'year2023'; - const actual = yearValueToString(dateObject); - expect(actual).toEqual(expectedYear); - }); - - test('sort release notes by created date in descending order', () => { - const sorted = sortReleaseNotesByDate(notes); - const expected = [ - { createdDate: '2023-06-29' }, - { createdDate: '2023-01-17' }, - { createdDate: '2022-08-31' }, - { createdDate: '2022-06-29' }, - { createdDate: '2020-06-29' }, - { createdDate: undefined }, - { createdDate: undefined }, - ]; - expect(sorted).toStrictEqual(expected); - }); -}); diff --git a/src/utils/releaseNotes.ts b/src/utils/releaseNotes.ts deleted file mode 100644 index d49ae24..0000000 --- a/src/utils/releaseNotes.ts +++ /dev/null @@ -1,110 +0,0 @@ -import { TableOfContentsItemType } from '@equinor/amplify-components'; - -import { ReleaseNote } from 'src/api/models/ReleaseNote'; - -const extractDatesFromReleaseNotes = ( - releaseNotes: ReleaseNote[] -): TableOfContentsItemType[] => { - const pageMenuItemFormattedNotes: TableOfContentsItemType[] = []; - - const releaseNotesWithDate = releaseNotes.filter((n) => n.createdDate); - - const releaseNotesDates = releaseNotesWithDate.map((n) => { - const date = new Date(n.createdDate!); - - return { date, year: date.getFullYear(), month: date.getMonth() }; - }); - - for (const note of releaseNotesWithDate) { - const createdDate = new Date(note.createdDate!); - const yearLabel = createdDate.toLocaleString('en-US', { - year: 'numeric', - }); - const yearValue = `year${createdDate.toLocaleString('en-US', { - year: 'numeric', - })}`; - // Check if the year already exists, move on if it does - const existingYear = pageMenuItemFormattedNotes.find( - (p) => p.value === yearValue - ); - if (existingYear) { - continue; - } - - const matchingDatesOnYear = releaseNotesDates.filter( - (d) => d.year === createdDate.getFullYear() - ); - - const uniqueMonths = [ - ...new Map(matchingDatesOnYear.map((m) => [m.month, m])).values(), - ]; - - uniqueMonths.sort((a, b) => { - return b.date.getTime() - a.date.getTime(); - }); - - const months = uniqueMonths.map((d) => { - const monthLabel = d.date.toLocaleString('en-US', { - month: 'long', - }); - const monthValue = `${yearValue}--${monthLabel}`; - return { - label: monthLabel, - value: monthValue, - }; - }); - - pageMenuItemFormattedNotes.push({ - label: yearLabel, - value: yearValue, - children: months, - }); - } - - pageMenuItemFormattedNotes.sort((a, b) => { - const yearA = parseInt(a.label); - const yearB = parseInt(b.label); - return yearB - yearA; - }); - - return pageMenuItemFormattedNotes; -}; - -const monthValueToString = (monthValue: Date) => { - return `year${monthValue.getFullYear()}--${monthValue.toLocaleDateString( - 'en-GB', - { - month: 'long', - } - )}`; -}; - -const monthToString = (monthValue: Date) => { - return `${monthValue.toLocaleDateString('en-GB', { - month: 'long', - })}`; -}; - -const yearValueToString = (yearValue: Date) => { - return `year${yearValue.toLocaleDateString('en-GB', { - year: 'numeric', - })}`; -}; - -const sortReleaseNotesByDate = (notes: ReleaseNote[]) => { - return notes.sort((a, b) => { - const dateA = new Date(a.createdDate ?? '').getTime(); - const dateB = new Date(b.createdDate ?? '').getTime(); - const numberDateA = !Number.isNaN(dateA) ? dateA : 0; - const numberDateB = !Number.isNaN(dateB) ? dateB : 0; - return numberDateB - numberDateA; - }); -}; - -export { - extractDatesFromReleaseNotes, - monthToString, - monthValueToString, - sortReleaseNotesByDate, - yearValueToString, -};