diff --git a/src/short-urls/helpers/QrCodeModal.tsx b/src/short-urls/helpers/QrCodeModal.tsx index 081925e1..a16d6654 100644 --- a/src/short-urls/helpers/QrCodeModal.tsx +++ b/src/short-urls/helpers/QrCodeModal.tsx @@ -7,11 +7,7 @@ import { ShortUrlModalProps } from '../data'; import { SelectedServer } from '../../servers/data'; import { CopyToClipboardIcon } from '../../utils/CopyToClipboardIcon'; import { buildQrCodeUrl, QrCodeCapabilities, QrCodeFormat, QrErrorCorrection } from '../../utils/helpers/qrCodes'; -import { - supportsQrCodeSizeInQuery, - supportsQrCodeMargin, - supportsQrErrorCorrection, -} from '../../utils/helpers/features'; +import { supportsQrErrorCorrection } from '../../utils/helpers/features'; import { ImageDownloader } from '../../common/services/ImageDownloader'; import { ForServerVersionProps } from '../../servers/helpers/ForServerVersion'; import { QrFormatDropdown } from './qr-codes/QrFormatDropdown'; @@ -30,11 +26,9 @@ const QrCodeModal = (imageDownloader: ImageDownloader, ForServerVersion: FC('png'); const [errorCorrection, setErrorCorrection] = useState('L'); const capabilities: QrCodeCapabilities = useMemo(() => ({ - useSizeInPath: !supportsQrCodeSizeInQuery(selectedServer), - marginIsSupported: supportsQrCodeMargin(selectedServer), errorCorrectionIsSupported: supportsQrErrorCorrection(selectedServer), }), [selectedServer]); - const willRenderThreeControls = capabilities.marginIsSupported !== capabilities.errorCorrectionIsSupported; + const willRenderThreeControls = !capabilities.errorCorrectionIsSupported; const qrCodeUrl = useMemo( () => buildQrCodeUrl(shortUrl, { size, format, margin, errorCorrection }, capabilities), [shortUrl, size, format, margin, errorCorrection, capabilities], @@ -67,21 +61,19 @@ const QrCodeModal = (imageDownloader: ImageDownloader, ForServerVersion: FC setSize(Number(e.target.value))} /> - {capabilities.marginIsSupported && ( - - - setMargin(Number(e.target.value))} - /> - - )} + + + setMargin(Number(e.target.value))} + /> + diff --git a/src/utils/helpers/features.ts b/src/utils/helpers/features.ts index 54a26c7d..47887fb4 100644 --- a/src/utils/helpers/features.ts +++ b/src/utils/helpers/features.ts @@ -4,10 +4,8 @@ import { versionMatch, Versions } from './version'; const serverMatchesVersions = (versions: Versions) => (selectedServer: SelectedServer): boolean => isReachableServer(selectedServer) && versionMatch(selectedServer.version, versions); -export const supportsQrCodeSizeInQuery = serverMatchesVersions({ minVersion: '2.5.0' }); export const supportsShortUrlTitle = serverMatchesVersions({ minVersion: '2.6.0' }); export const supportsOrphanVisits = supportsShortUrlTitle; -export const supportsQrCodeMargin = supportsShortUrlTitle; export const supportsBotVisits = serverMatchesVersions({ minVersion: '2.7.0' }); export const supportsCrawlableVisits = supportsBotVisits; export const supportsQrErrorCorrection = serverMatchesVersions({ minVersion: '2.8.0' }); diff --git a/src/utils/helpers/qrCodes.ts b/src/utils/helpers/qrCodes.ts index c096f148..85feb888 100644 --- a/src/utils/helpers/qrCodes.ts +++ b/src/utils/helpers/qrCodes.ts @@ -2,8 +2,6 @@ import { isEmpty } from 'ramda'; import { stringifyQuery } from './query'; export interface QrCodeCapabilities { - useSizeInPath: boolean; - marginIsSupported: boolean; errorCorrectionIsSupported: boolean; } @@ -21,13 +19,13 @@ export interface QrCodeOptions { export const buildQrCodeUrl = ( shortUrl: string, { size, format, margin, errorCorrection }: QrCodeOptions, - { useSizeInPath, marginIsSupported, errorCorrectionIsSupported }: QrCodeCapabilities, + { errorCorrectionIsSupported }: QrCodeCapabilities, ): string => { - const baseUrl = `${shortUrl}/qr-code${useSizeInPath ? `/${size}` : ''}`; + const baseUrl = `${shortUrl}/qr-code`; const query = stringifyQuery({ - size: useSizeInPath ? undefined : size, + size, format, - margin: marginIsSupported && margin > 0 ? margin : undefined, + margin: margin > 0 ? margin : undefined, errorCorrection: errorCorrectionIsSupported ? errorCorrection : undefined, }); diff --git a/test/utils/helpers/qrCodes.test.ts b/test/utils/helpers/qrCodes.test.ts index 5a2edf22..bfd72b13 100644 --- a/test/utils/helpers/qrCodes.test.ts +++ b/test/utils/helpers/qrCodes.test.ts @@ -3,71 +3,41 @@ import { buildQrCodeUrl, QrCodeFormat, QrErrorCorrection } from '../../../src/ut describe('qrCodes', () => { describe('buildQrCodeUrl', () => { it.each([ - [ - 'foo.com', - { size: 530, format: 'svg' as QrCodeFormat, margin: 0, errorCorrection: 'L' as QrErrorCorrection }, - { useSizeInPath: true, marginIsSupported: false, errorCorrectionIsSupported: false }, - 'foo.com/qr-code/530?format=svg', - ], - [ - 'foo.com', - { size: 530, format: 'png' as QrCodeFormat, margin: 0, errorCorrection: 'L' as QrErrorCorrection }, - { useSizeInPath: true, marginIsSupported: false, errorCorrectionIsSupported: false }, - 'foo.com/qr-code/530?format=png', - ], [ 'bar.io', { size: 870, format: 'svg' as QrCodeFormat, margin: 0, errorCorrection: 'L' as QrErrorCorrection }, - { useSizeInPath: false, marginIsSupported: false, errorCorrectionIsSupported: false }, + { errorCorrectionIsSupported: false }, 'bar.io/qr-code?size=870&format=svg', ], [ 'bar.io', { size: 200, format: 'png' as QrCodeFormat, margin: 0, errorCorrection: 'L' as QrErrorCorrection }, - { useSizeInPath: false, marginIsSupported: false, errorCorrectionIsSupported: false }, + { errorCorrectionIsSupported: false }, 'bar.io/qr-code?size=200&format=png', ], [ 'bar.io', { size: 200, format: 'svg' as QrCodeFormat, margin: 0, errorCorrection: 'L' as QrErrorCorrection }, - { useSizeInPath: false, marginIsSupported: false, errorCorrectionIsSupported: false }, + { errorCorrectionIsSupported: false }, 'bar.io/qr-code?size=200&format=svg', ], - [ - 'foo.net', - { size: 480, format: 'png' as QrCodeFormat, margin: 0, errorCorrection: 'L' as QrErrorCorrection }, - { useSizeInPath: true, marginIsSupported: false, errorCorrectionIsSupported: false }, - 'foo.net/qr-code/480?format=png', - ], - [ - 'foo.net', - { size: 480, format: 'svg' as QrCodeFormat, margin: 0, errorCorrection: 'L' as QrErrorCorrection }, - { useSizeInPath: true, marginIsSupported: false, errorCorrectionIsSupported: false }, - 'foo.net/qr-code/480?format=svg', - ], - [ - 'shlink.io', - { size: 123, format: 'svg' as QrCodeFormat, margin: 10, errorCorrection: 'L' as QrErrorCorrection }, - { useSizeInPath: true, marginIsSupported: false, errorCorrectionIsSupported: false }, - 'shlink.io/qr-code/123?format=svg', - ], [ 'shlink.io', { size: 456, format: 'png' as QrCodeFormat, margin: 10, errorCorrection: 'L' as QrErrorCorrection }, - { useSizeInPath: true, marginIsSupported: true, errorCorrectionIsSupported: false }, - 'shlink.io/qr-code/456?format=png&margin=10', - ], - [ - 'shlink.io', - { size: 456, format: 'png' as QrCodeFormat, margin: 0, errorCorrection: 'L' as QrErrorCorrection }, - { useSizeInPath: true, marginIsSupported: true, errorCorrectionIsSupported: false }, - 'shlink.io/qr-code/456?format=png', + { errorCorrectionIsSupported: false }, + 'shlink.io/qr-code?size=456&format=png&margin=10', ], [ 'shlink.io', { size: 456, format: 'png' as QrCodeFormat, margin: 0, errorCorrection: 'H' as QrErrorCorrection }, - { useSizeInPath: true, marginIsSupported: true, errorCorrectionIsSupported: true }, - 'shlink.io/qr-code/456?format=png&errorCorrection=H', + { errorCorrectionIsSupported: true }, + 'shlink.io/qr-code?size=456&format=png&errorCorrection=H', + ], + [ + 'shlink.io', + { size: 999, format: 'png' as QrCodeFormat, margin: 20, errorCorrection: 'Q' as QrErrorCorrection }, + { errorCorrectionIsSupported: true }, + 'shlink.io/qr-code?size=999&format=png&margin=20&errorCorrection=Q', ], ])('builds expected URL based in params', (shortUrl, options, capabilities, expectedUrl) => { expect(buildQrCodeUrl(shortUrl, options, capabilities)).toEqual(expectedUrl);