1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-02 12:47:41 +02:00

Mobile: Resolves #10360: Make most plugins default to being desktop-only (#10376)

This commit is contained in:
Henry Heino 2024-04-27 03:43:25 -07:00 committed by GitHub
parent 034e568d26
commit 03617eb8a7
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
8 changed files with 64 additions and 9 deletions

View File

@ -1071,6 +1071,7 @@ packages/lib/services/plugins/utils/getPluginIssueReportUrl.js
packages/lib/services/plugins/utils/getPluginNamespacedSettingKey.js packages/lib/services/plugins/utils/getPluginNamespacedSettingKey.js
packages/lib/services/plugins/utils/getPluginSettingKeyPrefix.js packages/lib/services/plugins/utils/getPluginSettingKeyPrefix.js
packages/lib/services/plugins/utils/getPluginSettingValue.js packages/lib/services/plugins/utils/getPluginSettingValue.js
packages/lib/services/plugins/utils/isCompatible/getDefaultPlatforms.js
packages/lib/services/plugins/utils/isCompatible/index.test.js packages/lib/services/plugins/utils/isCompatible/index.test.js
packages/lib/services/plugins/utils/isCompatible/index.js packages/lib/services/plugins/utils/isCompatible/index.js
packages/lib/services/plugins/utils/isCompatible/minVersionForPlatform.js packages/lib/services/plugins/utils/isCompatible/minVersionForPlatform.js

1
.gitignore vendored
View File

@ -1051,6 +1051,7 @@ packages/lib/services/plugins/utils/getPluginIssueReportUrl.js
packages/lib/services/plugins/utils/getPluginNamespacedSettingKey.js packages/lib/services/plugins/utils/getPluginNamespacedSettingKey.js
packages/lib/services/plugins/utils/getPluginSettingKeyPrefix.js packages/lib/services/plugins/utils/getPluginSettingKeyPrefix.js
packages/lib/services/plugins/utils/getPluginSettingValue.js packages/lib/services/plugins/utils/getPluginSettingValue.js
packages/lib/services/plugins/utils/isCompatible/getDefaultPlatforms.js
packages/lib/services/plugins/utils/isCompatible/index.test.js packages/lib/services/plugins/utils/isCompatible/index.test.js
packages/lib/services/plugins/utils/isCompatible/index.js packages/lib/services/plugins/utils/isCompatible/index.js
packages/lib/services/plugins/utils/isCompatible/minVersionForPlatform.js packages/lib/services/plugins/utils/isCompatible/minVersionForPlatform.js

View File

@ -283,10 +283,11 @@ describe('services_PluginService', () => {
shouldRun: true, shouldRun: true,
}, },
{ {
// Should default to desktop-only
manifestPlatforms: [], manifestPlatforms: [],
isDesktop: false, isDesktop: false,
appVersion: '3.0.8', appVersion: '3.0.8',
shouldRun: true, shouldRun: false,
}, },
])('should enable and disable plugins depending on what platform(s) they support (case %#: %j)', async ({ manifestPlatforms, isDesktop, appVersion, shouldRun }) => { ])('should enable and disable plugins depending on what platform(s) they support (case %#: %j)', async ({ manifestPlatforms, isDesktop, appVersion, shouldRun }) => {
const pluginScript = ` const pluginScript = `

View File

@ -0,0 +1,43 @@
// Although `platforms: ['desktop', 'mobile']` is required to support both mobile
// and desktop, no plugin authors have done this as of 04/25/2024. As such, we include
// a list of plugins that have "platforms" default to ['desktop', 'mobile'] rather
// than just ['desktop'].
// cSpell:disable
const defaultSupportMobile = [
'com.github.joplin.kanban',
'com.hieuthi.joplin.function-plot',
'com.hieuthi.joplin.markdown-table-colorize',
'com.joplin.copy.codeBlocks',
'com.whatever.inline-tags',
'com.whatever.quick-links',
'cx.evermeet.tessus.menu-shortcut-toolbar',
'io.github.personalizedrefrigerator.codemirror6-settings',
'io.github.personalizedrefrigerator.revealjs-integration',
'io.treymo.LinkGraph',
'jl15988.JoplinAlertsPerfectPlugin',
'jl15988.JoplinCodePerfectPlugin',
'joplin.plugin.alondmnt.history-panel',
'joplin.plugin.ambrt.backlinksToNote',
'joplin.plugin.ambrt.embedSearch',
'joplin.plugin.note.tabs',
'joplin.plugin.spoiler.cards',
'net.cwesson.joplin-plugin-typograms',
'org.joplinapp.plugins.AbcSheetMusic',
'org.joplinapp.plugins.admonition',
'org.joplinapp.plugins.joplin-calendar',
'outline',
'plugin.calebjohn.MathMode',
'plugin.calebjohn.rich-markdown',
];
// cSpell:enable
const getDefaultPluginPlatforms = (id: string) => {
if (defaultSupportMobile.includes(id)) {
return ['desktop', 'mobile'];
} else {
return ['desktop'];
}
};
export default getDefaultPluginPlatforms;

View File

@ -8,7 +8,7 @@ describe('isCompatible', () => {
manifest: { app_min_version: '2.0' }, manifest: { app_min_version: '2.0' },
appVersion: '2.1.0', appVersion: '2.1.0',
shouldSupportDesktop: true, shouldSupportDesktop: true,
shouldSupportMobile: true, shouldSupportMobile: false,
}, },
{ {
manifest: { app_min_version: '2.0' }, manifest: { app_min_version: '2.0' },
@ -20,7 +20,7 @@ describe('isCompatible', () => {
manifest: { app_min_version: '3.0.2' }, manifest: { app_min_version: '3.0.2' },
appVersion: '3.0.2', appVersion: '3.0.2',
shouldSupportDesktop: true, shouldSupportDesktop: true,
shouldSupportMobile: true, shouldSupportMobile: false,
}, },
// Should support the case where only one platform is provided, with no version // Should support the case where only one platform is provided, with no version
@ -83,9 +83,13 @@ describe('isCompatible', () => {
shouldSupportMobile: true, shouldSupportMobile: true,
}, },
])('should correctly return whether a plugin is compatible with a given version of Joplin (case %#: %j)', ({ manifest, appVersion, shouldSupportDesktop, shouldSupportMobile }) => { ])('should correctly return whether a plugin is compatible with a given version of Joplin (case %#: %j)', ({ manifest, appVersion, shouldSupportDesktop, shouldSupportMobile }) => {
const mobileCompatible = isCompatible(appVersion, AppType.Mobile, manifest); const fullManifest = {
id: 'com.example.id',
...manifest,
};
const mobileCompatible = isCompatible(appVersion, AppType.Mobile, fullManifest);
expect(mobileCompatible).toBe(shouldSupportMobile); expect(mobileCompatible).toBe(shouldSupportMobile);
const desktopCompatible = isCompatible(appVersion, AppType.Desktop, manifest); const desktopCompatible = isCompatible(appVersion, AppType.Desktop, fullManifest);
expect(desktopCompatible).toBe(shouldSupportDesktop); expect(desktopCompatible).toBe(shouldSupportDesktop);
}); });
}); });

View File

@ -1,10 +1,15 @@
import { AppType } from '../../../../models/Setting'; import { AppType } from '../../../../models/Setting';
import getDefaultPlatforms from './getDefaultPlatforms';
import { ManifestSlice } from './types'; import { ManifestSlice } from './types';
// Returns false if the platform isn't supported at all, // Returns false if the platform isn't supported at all,
const minVersionForPlatform = (appPlatform: AppType, manifest: ManifestSlice): string|false => { const minVersionForPlatform = (appPlatform: AppType, manifest: ManifestSlice): string|false => {
const platforms = manifest.platforms ?? []; let platforms = manifest.platforms;
// If platforms is not specified (or empty), default to supporting all platforms.
if (!platforms || platforms.length === 0) {
platforms = getDefaultPlatforms(manifest.id);
}
const supported = platforms.length === 0 || platforms.includes(appPlatform); const supported = platforms.length === 0 || platforms.includes(appPlatform);
if (!supported) { if (!supported) {
return false; return false;

View File

@ -1,3 +1,3 @@
import { PluginManifest } from '../types'; import { PluginManifest } from '../types';
export type ManifestSlice = Pick<PluginManifest, 'app_min_version'|'app_min_version_mobile'|'platforms'>; export type ManifestSlice = Pick<PluginManifest, 'id'|'app_min_version'|'app_min_version_mobile'|'platforms'>;

View File

@ -22,7 +22,7 @@ Name | Type | Required? | Description
## Platforms ## Platforms
A list that can contain `"desktop"` and/or `"mobile"`. A list that can contain `"desktop"` and/or `"mobile"`. If not given, it defaults to `[ "desktop" ]` for most plugins.
## Categories ## Categories