2
0
mirror of https://github.com/inventree/InvenTree.git synced 2026-05-06 17:53:44 +00:00
* [UI] Small visual tweaks for plugin settings panel

Co-authored-by: Copilot <copilot@github.com>

* Refactor common code

Co-authored-by: Copilot <copilot@github.com>

* Reduce code duplication

---------

Co-authored-by: Copilot <copilot@github.com>
This commit is contained in:
Oliver
2026-05-05 10:15:04 +10:00
committed by GitHub
parent c68fda9916
commit 3c3964062f
2 changed files with 32 additions and 16 deletions
@@ -19,6 +19,18 @@ const PluginErrorTable = Loadable(
lazy(() => import('../../../../tables/plugin/PluginErrorTable')) lazy(() => import('../../../../tables/plugin/PluginErrorTable'))
); );
export const PLUGIN_SETTINGS_KEYS = [
'ENABLE_PLUGINS_SCHEDULE',
'ENABLE_PLUGINS_EVENTS',
'ENABLE_PLUGINS_INTERFACE',
'ENABLE_PLUGINS_URL',
'ENABLE_PLUGINS_NAVIGATION',
'ENABLE_PLUGINS_APP',
'ENABLE_PLUGINS_MAILS',
'PLUGIN_ON_STARTUP',
'PLUGIN_UPDATE_CHECK'
];
export default function PluginManagementPanel() { export default function PluginManagementPanel() {
const pluginsEnabled = useServerApiState( const pluginsEnabled = useServerApiState(
useShallow((state) => state.server.plugins_enabled) useShallow((state) => state.server.plugins_enabled)
@@ -55,19 +67,7 @@ export default function PluginManagementPanel() {
<StylishText size='lg'>{t`Plugin Settings`}</StylishText> <StylishText size='lg'>{t`Plugin Settings`}</StylishText>
</Accordion.Control> </Accordion.Control>
<Accordion.Panel> <Accordion.Panel>
<GlobalSettingList <GlobalSettingList keys={PLUGIN_SETTINGS_KEYS} />
keys={[
'ENABLE_PLUGINS_SCHEDULE',
'ENABLE_PLUGINS_EVENTS',
'ENABLE_PLUGINS_INTERFACE',
'ENABLE_PLUGINS_URL',
'ENABLE_PLUGINS_NAVIGATION',
'ENABLE_PLUGINS_APP',
'ENABLE_PLUGINS_MAILS',
'PLUGIN_ON_STARTUP',
'PLUGIN_UPDATE_CHECK'
]}
/>
</Accordion.Panel> </Accordion.Panel>
</Accordion.Item> </Accordion.Item>
{user.isSuperuser() && ( {user.isSuperuser() && (
@@ -1,14 +1,16 @@
import { ApiEndpoints } from '@lib/index'; import { ApiEndpoints, StylishText } from '@lib/index';
import type { SettingsStateProps } from '@lib/types/Settings'; import type { SettingsStateProps } from '@lib/types/Settings';
import { t } from '@lingui/core/macro'; import { t } from '@lingui/core/macro';
import { Accordion, Alert, Group, Stack, Text } from '@mantine/core'; import { Accordion, Alert, Group, Stack, Text } from '@mantine/core';
import { IconInfoCircle } from '@tabler/icons-react'; import { IconInfoCircle } from '@tabler/icons-react';
import { useCallback, useMemo, useState } from 'react'; import { useCallback, useMemo, useState } from 'react';
import { import {
GlobalSettingList,
PluginSettingList, PluginSettingList,
PluginUserSettingList PluginUserSettingList
} from '../../../components/settings/SettingList'; } from '../../../components/settings/SettingList';
import { useInstance } from '../../../hooks/UseInstance'; import { useInstance } from '../../../hooks/UseInstance';
import { PLUGIN_SETTINGS_KEYS } from './AdminCenter/PluginManagementPanel';
function PluginSettingGroupItem({ function PluginSettingGroupItem({
global, global,
@@ -39,9 +41,13 @@ function PluginSettingGroupItem({
hidden={count === 0} hidden={count === 0}
> >
<Accordion.Control> <Accordion.Control>
<Group> <Group justify='space-between'>
<Text size='lg'>{pluginName}</Text> <Text size='lg'>{pluginName}</Text>
{pluginDescription && <Text size='sm'>{pluginDescription}</Text>} {pluginDescription && (
<Text size='sm' style={{ paddingRight: 25 }}>
{pluginDescription}
</Text>
)}
</Group> </Group>
</Accordion.Control> </Accordion.Control>
<Accordion.Panel> <Accordion.Panel>
@@ -93,6 +99,16 @@ export default function PluginSettingsGroup({
return ( return (
<Stack gap='xs'> <Stack gap='xs'>
<Accordion defaultValue='plugin-settings'>
<Accordion.Item value='plugin-settings'>
<Accordion.Control>
<StylishText size='lg'>{t`Plugin Settings`}</StylishText>
</Accordion.Control>
<Accordion.Panel>
<GlobalSettingList keys={PLUGIN_SETTINGS_KEYS} />
</Accordion.Panel>
</Accordion.Item>
</Accordion>
<Alert color='blue' icon={<IconInfoCircle />}> <Alert color='blue' icon={<IconInfoCircle />}>
<Text> <Text>
{message ?? {message ??