From 96e73fc6638e0fbf94341d21709be10210e08e6a Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Fri, 8 Mar 2024 10:00:03 +0200 Subject: [PATCH 01/15] Turn off ipc log transport between render and main process --- src/error-manager/index.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/error-manager/index.js b/src/error-manager/index.js index f8479831..0ab95ba3 100644 --- a/src/error-manager/index.js +++ b/src/error-manager/index.js @@ -169,6 +169,7 @@ const manageNewGithubIssue = async (params) => { } const initLogger = () => { + log.transports.ipc.level = false log.transports.console.level = isDevEnv ? 'debug' : 'warn' From 8cbfc2eedacf6745890ddd8110ce9a93884399d4 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Fri, 8 Mar 2024 10:08:40 +0200 Subject: [PATCH 02/15] Suppress err modal window if pdf gen failed --- src/error-manager/index.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/error-manager/index.js b/src/error-manager/index.js index 0ab95ba3..5a82a4bf 100644 --- a/src/error-manager/index.js +++ b/src/error-manager/index.js @@ -216,7 +216,9 @@ const initLogger = () => { if ( /Cannot download differentially/gi.test(error) || /ERR_CONNECTION_REFUSED/gi.test(error) || - /objects\.githubusercontent\.com/gi.test(error) + /objects\.githubusercontent\.com/gi.test(error) || + /Error: ERR_FAILED \(-2\) loading 'file:.*\.html'/gi.test(error) || + /Failed to generate PDF/gi.test(error) ) { return message } From b4ed6fe4737e604ae2cc91d9c1385b314c776206 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Fri, 8 Mar 2024 10:10:55 +0200 Subject: [PATCH 03/15] Improve pdf gen performance for big html templates --- src/print-to-pdf/index.js | 40 +++++++++++++++++++++++---------------- 1 file changed, 24 insertions(+), 16 deletions(-) diff --git a/src/print-to-pdf/index.js b/src/print-to-pdf/index.js index 150b421a..460738e6 100644 --- a/src/print-to-pdf/index.js +++ b/src/print-to-pdf/index.js @@ -16,6 +16,8 @@ const PROCESS_STATES = require( module.exports = () => { ipcs.serverIpc.on('message', async (mess) => { + let templateFilePathForRm = null + try { if (mess?.state !== PROCESS_MESSAGES.REQUEST_PDF_CREATION) { return @@ -33,14 +35,9 @@ module.exports = () => { templateFilePath && typeof templateFilePath === 'string' ) - - const html = isTemplateFilePathUsed - ? await fs.readFile(templateFilePath, { encoding: 'utf8' }) - : template - - if (isTemplateFilePathUsed) { - await fs.rm(templateFilePath, { force: true, maxRetries: 3 }) - } + templateFilePathForRm = isTemplateFilePathUsed + ? templateFilePath + : null const win = new BrowserWindow({ show: false, @@ -49,14 +46,15 @@ module.exports = () => { nodeIntegration: true } }) - win.loadURL(`data:text/html;charset=utf-8,${encodeURIComponent(html)}`) + const closedEventPromise = new Promise((resolve) => ( + win.once('closed', resolve) + )) + const loadPromise = isTemplateFilePathUsed + ? win.loadFile(templateFilePath) + : win.loadURL(`data:text/html;charset=utf-8,${encodeURIComponent(template)}`) + + await loadPromise - await new Promise((resolve, reject) => { - win.webContents.on('did-finish-load', resolve) - win.webContents.on('did-fail-load', (e, code, err) => { - reject(err) - }) - }) const buffer = await win.webContents.printToPDF({ landscape: format !== 'portrait', pageSize: orientation, @@ -79,7 +77,12 @@ module.exports = () => { ` }) + win.close() + await closedEventPromise + if (isTemplateFilePathUsed) { + await fs.rm(templateFilePath, { force: true, maxRetries: 3 }) + const { dir, name } = path.parse(templateFilePath) const pdfFilePath = path.format({ dir, name, ext: '.pdf' }) @@ -98,9 +101,14 @@ module.exports = () => { data: { buffer, uid } }) } catch (err) { + if (templateFilePathForRm) { + fs.rm(templateFilePathForRm, { force: true, maxRetries: 3 }) + .then(() => {}, (err) => { console.debug(err) }) + } + ipcs.serverIpc.send({ state: PROCESS_STATES.RESPONSE_PDF_CREATION, - data: { err, uid: mess?.data?.uid ?? null } + data: { err: err.stack ?? err, uid: mess?.data?.uid ?? null } }) console.error(err) From 0c182673aebceddaa247c8c4afd16c22e7a8c0e4 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Fri, 8 Mar 2024 10:27:32 +0200 Subject: [PATCH 04/15] Bump up electron minor version --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index c048db90..57a3adfa 100644 --- a/package.json +++ b/package.json @@ -43,7 +43,7 @@ "app-builder-bin": "4.2.0", "cross-env": "7.0.3", "dotenv": "16.3.1", - "electron": "27.2.0", + "electron": "27.3.5", "electron-builder": "24.10.0", "mocha": "10.2.0", "standard": "17.1.0", From b4fca2a9ffc59193333a49e4a5f917b404d6cc68 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Tue, 12 Mar 2024 09:48:38 +0200 Subject: [PATCH 05/15] Use test report generators without artifact opt --- .github/workflows/test-report.yml | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/.github/workflows/test-report.yml b/.github/workflows/test-report.yml index 107c4a83..089682c4 100644 --- a/.github/workflows/test-report.yml +++ b/.github/workflows/test-report.yml @@ -18,12 +18,16 @@ jobs: runs-on: ubuntu-22.04 if: ${{ github.event.workflow_run.conclusion == 'success' }} steps: - - uses: dorny/test-reporter@v1 + - name: Download test results + uses: actions/download-artifact@v4 + with: + name: test-results + path: test-results + - uses: dorny/test-reporter@v1.8.0 id: test-results with: - artifact: test-results name: Mocha Tests - path: test-report.json + path: test-results/test-report.json reporter: mocha-json - name: Test Report Summary run: | From 2e207eebecc7cf3db7d678aa7757e3aaf9bafdd9 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Tue, 12 Mar 2024 09:49:18 +0200 Subject: [PATCH 06/15] Use actions/upload-artifact v4 for uploading e2e test results --- .github/workflows/build-electron-app.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/build-electron-app.yml b/.github/workflows/build-electron-app.yml index 6f2cded9..64acd22c 100644 --- a/.github/workflows/build-electron-app.yml +++ b/.github/workflows/build-electron-app.yml @@ -214,7 +214,7 @@ jobs: - name: Normalize E2E test report run: node ./scripts/node/normalize-e2e-test-report e2e-test-report.xml - name: Upload Linux E2E test results - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: linux-e2e-test-results path: e2e-test-report.xml @@ -246,7 +246,7 @@ jobs: - name: Normalize E2E test report run: node ./scripts/node/normalize-e2e-test-report e2e-test-report.xml - name: Upload Win E2E test results - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: win-e2e-test-results path: e2e-test-report.xml @@ -280,7 +280,7 @@ jobs: - name: Normalize E2E test report run: node ./scripts/node/normalize-e2e-test-report e2e-test-report.xml - name: Upload Mac E2E test results - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: mac-e2e-test-results path: e2e-test-report.xml From f7aa2dfda06b5a7187166ae65e429d13cf510198 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Tue, 12 Mar 2024 09:51:13 +0200 Subject: [PATCH 07/15] Use actions/upload-artifact v4 for uploading test results --- .github/workflows/ci.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index acf4b350..1941df0c 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -25,7 +25,7 @@ jobs: run: ./scripts/setup.sh -u - name: Run tests run: npm test -- -- --reporter=json --reporter-option output=test-report.json - - uses: actions/upload-artifact@v3 + - uses: actions/upload-artifact@v4 if: success() || failure() with: name: test-results From 4c08582382c0419b81cca16db00eef7f8ffd9342 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Tue, 12 Mar 2024 09:53:34 +0200 Subject: [PATCH 08/15] Use e2e test report generators without artifact opt --- .github/workflows/e2e-test-report.yml | 30 +++++++++++++++++++-------- 1 file changed, 21 insertions(+), 9 deletions(-) diff --git a/.github/workflows/e2e-test-report.yml b/.github/workflows/e2e-test-report.yml index b353f0ad..4ae0855d 100644 --- a/.github/workflows/e2e-test-report.yml +++ b/.github/workflows/e2e-test-report.yml @@ -18,26 +18,38 @@ jobs: runs-on: ubuntu-22.04 if: ${{ github.event.workflow_run.conclusion == 'success' }} steps: - - uses: dorny/test-reporter@v1 + - name: Download Linux E2E test results + uses: actions/download-artifact@v4 + with: + name: linux-e2e-test-results + path: linux-e2e-test-results + - uses: dorny/test-reporter@v1.8.0 id: linux-e2e-test-results with: - artifact: linux-e2e-test-results name: Linux E2E Tests - path: e2e-test-report.xml + path: linux-e2e-test-results/e2e-test-report.xml reporter: jest-junit - - uses: dorny/test-reporter@v1 + - name: Download Win E2E test results + uses: actions/download-artifact@v4 + with: + name: win-e2e-test-results + path: win-e2e-test-results + - uses: dorny/test-reporter@v1.8.0 id: win-e2e-test-results with: - artifact: win-e2e-test-results name: Win E2E Tests - path: e2e-test-report.xml + path: win-e2e-test-results/e2e-test-report.xml reporter: jest-junit - - uses: dorny/test-reporter@v1 + - name: Download Mac E2E test results + uses: actions/download-artifact@v4 + with: + name: mac-e2e-test-results + path: mac-e2e-test-results + - uses: dorny/test-reporter@v1.8.0 id: mac-e2e-test-results with: - artifact: mac-e2e-test-results name: Mac E2E Tests - path: e2e-test-report.xml + path: mac-e2e-test-results/e2e-test-report.xml reporter: jest-junit - name: E2E Test Report Summary run: | From b27bfce9ce885a37313c8ef1b66bbeca91ab5080 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Tue, 12 Mar 2024 11:44:43 +0200 Subject: [PATCH 09/15] Fix test result download permission --- .github/workflows/e2e-test-report.yml | 6 ++++++ .github/workflows/test-report.yml | 2 ++ 2 files changed, 8 insertions(+) diff --git a/.github/workflows/e2e-test-report.yml b/.github/workflows/e2e-test-report.yml index 4ae0855d..f40734a4 100644 --- a/.github/workflows/e2e-test-report.yml +++ b/.github/workflows/e2e-test-report.yml @@ -21,6 +21,8 @@ jobs: - name: Download Linux E2E test results uses: actions/download-artifact@v4 with: + run-id: ${{ github.event.workflow_run.id }} + github-token: ${{ secrets.GITHUB_TOKEN }} name: linux-e2e-test-results path: linux-e2e-test-results - uses: dorny/test-reporter@v1.8.0 @@ -32,6 +34,8 @@ jobs: - name: Download Win E2E test results uses: actions/download-artifact@v4 with: + run-id: ${{ github.event.workflow_run.id }} + github-token: ${{ secrets.GITHUB_TOKEN }} name: win-e2e-test-results path: win-e2e-test-results - uses: dorny/test-reporter@v1.8.0 @@ -43,6 +47,8 @@ jobs: - name: Download Mac E2E test results uses: actions/download-artifact@v4 with: + run-id: ${{ github.event.workflow_run.id }} + github-token: ${{ secrets.GITHUB_TOKEN }} name: mac-e2e-test-results path: mac-e2e-test-results - uses: dorny/test-reporter@v1.8.0 diff --git a/.github/workflows/test-report.yml b/.github/workflows/test-report.yml index 089682c4..6793bb81 100644 --- a/.github/workflows/test-report.yml +++ b/.github/workflows/test-report.yml @@ -21,6 +21,8 @@ jobs: - name: Download test results uses: actions/download-artifact@v4 with: + run-id: ${{ github.event.workflow_run.id }} + github-token: ${{ secrets.GITHUB_TOKEN }} name: test-results path: test-results - uses: dorny/test-reporter@v1.8.0 From e21598accac384897f3c9cacea6be9f710840b30 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Tue, 12 Mar 2024 13:07:28 +0200 Subject: [PATCH 10/15] Add workaround for error 'fatal: not a git repository' caused by a call to 'git ls-files --- .github/workflows/e2e-test-report.yml | 5 +++++ .github/workflows/test-report.yml | 3 +++ 2 files changed, 8 insertions(+) diff --git a/.github/workflows/e2e-test-report.yml b/.github/workflows/e2e-test-report.yml index f40734a4..7ce5edd3 100644 --- a/.github/workflows/e2e-test-report.yml +++ b/.github/workflows/e2e-test-report.yml @@ -31,6 +31,9 @@ jobs: name: Linux E2E Tests path: linux-e2e-test-results/e2e-test-report.xml reporter: jest-junit + # Workaround for error 'fatal: not a git repository' caused by a call to 'git ls-files' + # See: https://github.com/dorny/test-reporter/issues/169#issuecomment-1583560458 + max-annotations: 0 - name: Download Win E2E test results uses: actions/download-artifact@v4 with: @@ -44,6 +47,7 @@ jobs: name: Win E2E Tests path: win-e2e-test-results/e2e-test-report.xml reporter: jest-junit + max-annotations: 0 - name: Download Mac E2E test results uses: actions/download-artifact@v4 with: @@ -57,6 +61,7 @@ jobs: name: Mac E2E Tests path: mac-e2e-test-results/e2e-test-report.xml reporter: jest-junit + max-annotations: 0 - name: E2E Test Report Summary run: | echo "### E2E Test Report page is ready! :rocket:" >> $GITHUB_STEP_SUMMARY diff --git a/.github/workflows/test-report.yml b/.github/workflows/test-report.yml index 6793bb81..bf11d9d5 100644 --- a/.github/workflows/test-report.yml +++ b/.github/workflows/test-report.yml @@ -31,6 +31,9 @@ jobs: name: Mocha Tests path: test-results/test-report.json reporter: mocha-json + # Workaround for error 'fatal: not a git repository' caused by a call to 'git ls-files' + # See: https://github.com/dorny/test-reporter/issues/169#issuecomment-1583560458 + max-annotations: 0 - name: Test Report Summary run: | echo "### Test Report page is ready! :rocket:" >> $GITHUB_STEP_SUMMARY From dcd4a3b8a9c49c08a543f782c3151a378d8db000 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Wed, 13 Mar 2024 14:21:21 +0200 Subject: [PATCH 11/15] Add ability to upload dist release if repo owner is customized --- .github/workflows/build-electron-app.yml | 40 ++++++++++++++++++++++-- 1 file changed, 38 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build-electron-app.yml b/.github/workflows/build-electron-app.yml index 64acd22c..37c05978 100644 --- a/.github/workflows/build-electron-app.yml +++ b/.github/workflows/build-electron-app.yml @@ -83,7 +83,12 @@ jobs: retry_wait_seconds: 10 max_attempts: 3 retry_on: any - command: ./scripts/launch.sh -lwp + command: | + if [[ "${REPO_OWNER}" != "${{ github.repository_owner }}" ]]; then + ./scripts/launch.sh -lw + else + ./scripts/launch.sh -lwp + fi - name: Zip Linux Unpacked build run: zip -r dist/linux-unpacked.zip dist/linux-unpacked - name: Upload Linux Unpacked build @@ -98,6 +103,24 @@ jobs: with: name: win-unpacked path: dist/win-unpacked.zip + - if: env.REPO_OWNER != github.repository_owner + name: Upload Linux Dist Release + uses: actions/upload-artifact@v4 + with: + name: linux-dist-release + path: | + dist/*-linux.AppImage + dist/*-linux.AppImage.zip + dist/latest-linux.yml + - if: env.REPO_OWNER != github.repository_owner + name: Upload Win Dist Release + uses: actions/upload-artifact@v4 + with: + name: win-dist-release + path: | + dist/*-win.exe + dist/*-win.exe.blockmap + dist/latest.yml - name: Prepare cache folders run: | sudo chown -R $(id -u):$(id -g) ~/.cache/electron @@ -178,7 +201,11 @@ jobs: if [[ -z "${APPLE_APP_SPECIFIC_PASSWORD}" || "${NOTARIZE:-}" != "1" ]]; then unset APPLE_APP_SPECIFIC_PASSWORD; fi if [[ -z "${CSC_LINK}" || "${NOTARIZE:-}" != "1" ]]; then unset CSC_LINK; fi if [[ -z "${CSC_KEY_PASSWORD}" || "${NOTARIZE:-}" != "1" ]]; then unset CSC_KEY_PASSWORD; fi - ./scripts/build-release.sh -mp + if [[ "${REPO_OWNER}" != "${{ github.repository_owner }}" ]]; then + ./scripts/build-release.sh -m + else + ./scripts/build-release.sh -mp + fi - name: Zip Mac Unpacked build run: zip -r dist/mac.zip dist/mac - name: Upload Mac Unpacked build @@ -186,6 +213,15 @@ jobs: with: name: mac-unpacked path: dist/mac.zip + - if: env.REPO_OWNER != github.repository_owner + name: Upload Mac Dist Release + uses: actions/upload-artifact@v4 + with: + name: mac-dist-release + path: | + dist/*-mac.zip + dist/*-mac.zip.blockmap + dist/latest-mac.yml linux-e2e-test-runner: name: Linux E2E Test Runner From 6890b921b0584a451ac7d4f57e57f25c20249ab1 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Thu, 14 Mar 2024 08:59:15 +0200 Subject: [PATCH 12/15] Pass --publish never flag into electron-builder --- scripts/build-release.sh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/scripts/build-release.sh b/scripts/build-release.sh index 27f93e1d..9c0a5b1b 100755 --- a/scripts/build-release.sh +++ b/scripts/build-release.sh @@ -226,6 +226,8 @@ publishOption="" if [ $isPublished == 1 ]; then # Available: 'onTag', 'onTagOrDraft', 'always', 'never' publishOption="--publish always" +else + publishOption="--publish never" fi rm -rf "$DIST_FOLDER/"*"$targetPlatform"* From e8f10408fa83f255e41b844d4ed5652a9490c5dd Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Wed, 20 Mar 2024 11:09:52 +0200 Subject: [PATCH 13/15] Bump version up to v4.21.0 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 57a3adfa..72d11c2d 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "bfx-report-electron", - "version": "4.20.0", + "version": "4.21.0", "repository": "https://github.com/bitfinexcom/bfx-report-electron", "description": "Reporting tool", "author": "bitfinex.com", From 511d3ca8616ace991a0ee1ee4b30417005280e7e Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Wed, 20 Mar 2024 11:10:51 +0200 Subject: [PATCH 14/15] Add changelog for v4.21.0 --- CHANGELOG.md | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index a4740f0f..c459631a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,28 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] +## [4.21.0] - 2024-03-20 + +### Added + +- Added ability to handle `PDFBufferUnderElectronCreationError` error to use WebSockets to inform users for better UX. PRs: [bfx-report#354](https://github.com/bitfinexcom/bfx-report/pull/354), [bfx-reports-framework#359](https://github.com/bitfinexcom/bfx-reports-framework/pull/359) +- Implemented support for `emitReportFileGenerationFailedToOne` ws events on UI side to inform users about report generation failing. PR: [bfx-report-ui#787](https://github.com/bitfinexcom/bfx-report-ui/pull/787) +- Added missing translations for PDF reports. PRs: [bfx-report#356](https://github.com/bitfinexcom/bfx-report/pull/356), [bfx-reports-framework#362](https://github.com/bitfinexcom/bfx-reports-framework/pull/362) +- Added DB migration for `publicCollsConf` table name with Cyrillic `c`. PR: [bfx-reports-framework#360](https://github.com/bitfinexcom/bfx-reports-framework/pull/360) +- Added migration for public colls conf endpoint name with Cyrillic `c`. PR: [bfx-report-ui#788](https://github.com/bitfinexcom/bfx-report-ui/pull/788) +- Added ability to upload dist release if repo owner is customized using manual build run. PR: [bfx-report-electron#347](https://github.com/bitfinexcom/bfx-report-electron/pull/347) + +### Changed + +- Updated `GH Actions` to use Nodejs `v20` to prevent breaking changes in workflow. PRs: [bfx-report#355](https://github.com/bitfinexcom/bfx-report/pull/355), [bfx-reports-framework#361](https://github.com/bitfinexcom/bfx-reports-framework/pull/361), [bfx-report-electron#344](https://github.com/bitfinexcom/bfx-report-electron/pull/344), [bfx-facs-db-better-sqlite#9](https://github.com/bitfinexcom/bfx-facs-db-better-sqlite/pull/9) +- Migrated from the `deprecated` reports generation methods usage to the actual ones according to the latest backend changes. PR: [bfx-report-ui#784](https://github.com/bitfinexcom/bfx-report-ui/pull/784) +- Allowed all pairs removal at the `Market History / Spot` section according to the latest UX improvement proposals: We should allow the user to remove the current pair and display an empty table that says `No history to display`. PR: [bfx-report-ui#786](https://github.com/bitfinexcom/bfx-report-ui/pull/786) +- Improved print PDF under Electronjs. Turned off ipc log transport between render and main process as unused, it prevents ipc transport error from `electron-log` lib. Suppressed error modal window if pdf gen failed: the idea here is to inform the user if something goes wrong using WS event for better UX instead of showing a modal window error as it is annoying in most cases. Improved pdf generation performance for big html templates, uses `loadFile` method of electron api instead of `base64` encoding. Bumped up Electronjs minor version to have the last fixes. PR: [bfx-report-electron#342](https://github.com/bitfinexcom/bfx-report-electron/pull/342) + +### Fixed + +- Prevented duplication possibility for items in the selectors of the UI. PR: [bfx-report-ui#785](https://github.com/bitfinexcom/bfx-report-ui/pull/785) + ## [4.20.0] - 2024-03-06 ### Added From cf55e3d607f4eec3b37116593fe4e8b4a9eb9325 Mon Sep 17 00:00:00 2001 From: Vladimir Voronkov Date: Wed, 20 Mar 2024 11:13:04 +0200 Subject: [PATCH 15/15] Update sub-modules --- bfx-report-ui | 2 +- bfx-reports-framework | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/bfx-report-ui b/bfx-report-ui index 3bad3486..a94ca364 160000 --- a/bfx-report-ui +++ b/bfx-report-ui @@ -1 +1 @@ -Subproject commit 3bad3486986d3cc5b44f7c85aa33591d55a5ab7c +Subproject commit a94ca364bd79d2852a69f86cc18ddefff860e895 diff --git a/bfx-reports-framework b/bfx-reports-framework index be1ed7b4..908d9cba 160000 --- a/bfx-reports-framework +++ b/bfx-reports-framework @@ -1 +1 @@ -Subproject commit be1ed7b41947675ed4bee8599fbed1dca747b80e +Subproject commit 908d9cba7dace99efee3f8f13aac3c31699fb72a