Browse Source

Update Permissions.svelte

Classic298 1 week ago
parent
commit
cf20f04bdc
1 changed files with 529 additions and 178 deletions
  1. 529 178
      src/lib/components/admin/Users/Groups/Permissions.svelte

+ 529 - 178
src/lib/components/admin/Users/Groups/Permissions.svelte

@@ -2,8 +2,8 @@
 	import { getContext, onMount } from 'svelte';
 	const i18n = getContext('i18n');
 
+	import Switch from '$lib/components/common/Switch.svelte';
 	import Tooltip from '$lib/components/common/Tooltip.svelte';
-	import PermissionSwitch from './PermissionSwitch.svelte';
 
 	// Default values for permissions
 	const DEFAULT_PERMISSIONS = {
@@ -77,30 +77,75 @@
 <div class="space-y-2">
 	<div>
 		<div class=" mb-2 text-sm font-medium">{$i18n.t('Workspace Permissions')}</div>
-		<div class="flex flex-col space-y-2">
-			<PermissionSwitch
-				label={$i18n.t('Models Access')}
-				bind:state={permissions.workspace.models}
-				defaultState={defaultPermissions?.workspace?.models}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Knowledge Access')}
-				bind:state={permissions.workspace.knowledge}
-				defaultState={defaultPermissions?.workspace?.knowledge}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Prompts Access')}
-				bind:state={permissions.workspace.prompts}
-				defaultState={defaultPermissions?.workspace?.prompts}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Tools Access')}
-				bind:state={permissions.workspace.tools}
-				defaultState={defaultPermissions?.workspace?.tools}
-				tooltip={$i18n.t(
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Models Access')}
+				</div>
+				<Switch bind:state={permissions.workspace.models} />
+			</div>
+			{#if defaultPermissions?.workspace?.models && !permissions.workspace.models}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Knowledge Access')}
+				</div>
+				<Switch bind:state={permissions.workspace.knowledge} />
+			</div>
+			{#if defaultPermissions?.workspace?.knowledge && !permissions.workspace.knowledge}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Prompts Access')}
+				</div>
+				<Switch bind:state={permissions.workspace.prompts} />
+			</div>
+			{#if defaultPermissions?.workspace?.prompts && !permissions.workspace.prompts}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<Tooltip
+				className="flex w-full justify-between my-2 pr-2"
+				content={$i18n.t(
 					'Warning: Enabling this will allow users to upload arbitrary code on the server.'
 				)}
-			/>
+				placement="top-start"
+			>
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Tools Access')}
+				</div>
+				<Switch bind:state={permissions.workspace.tools} />
+			</Tooltip>
+			{#if defaultPermissions?.workspace?.tools && !permissions.workspace.tools}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
 		</div>
 	</div>
 
@@ -108,32 +153,85 @@
 
 	<div>
 		<div class=" mb-2 text-sm font-medium">{$i18n.t('Sharing Permissions')}</div>
-		<div class="flex flex-col space-y-2">
-			<PermissionSwitch
-				label={$i18n.t('Models Public Sharing')}
-				bind:state={permissions.sharing.public_models}
-				defaultState={defaultPermissions?.sharing?.public_models}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Knowledge Public Sharing')}
-				bind:state={permissions.sharing.public_knowledge}
-				defaultState={defaultPermissions?.sharing?.public_knowledge}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Prompts Public Sharing')}
-				bind:state={permissions.sharing.public_prompts}
-				defaultState={defaultPermissions?.sharing?.public_prompts}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Tools Public Sharing')}
-				bind:state={permissions.sharing.public_tools}
-				defaultState={defaultPermissions?.sharing?.public_tools}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Notes Public Sharing')}
-				bind:state={permissions.sharing.public_notes}
-				defaultState={defaultPermissions?.sharing?.public_notes}
-			/>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Models Public Sharing')}
+				</div>
+				<Switch bind:state={permissions.sharing.public_models} />
+			</div>
+			{#if defaultPermissions?.sharing?.public_models && !permissions.sharing.public_models}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Knowledge Public Sharing')}
+				</div>
+				<Switch bind:state={permissions.sharing.public_knowledge} />
+			</div>
+			{#if defaultPermissions?.sharing?.public_knowledge && !permissions.sharing.public_knowledge}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Prompts Public Sharing')}
+				</div>
+				<Switch bind:state={permissions.sharing.public_prompts} />
+			</div>
+			{#if defaultPermissions?.sharing?.public_prompts && !permissions.sharing.public_prompts}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Tools Public Sharing')}
+				</div>
+				<Switch bind:state={permissions.sharing.public_tools} />
+			</div>
+			{#if defaultPermissions?.sharing?.public_tools && !permissions.sharing.public_tools}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Notes Public Sharing')}
+				</div>
+				<Switch bind:state={permissions.sharing.public_notes} />
+			</div>
+			{#if defaultPermissions?.sharing?.public_notes && !permissions.sharing.public_notes}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
 		</div>
 	</div>
 
@@ -141,146 +239,399 @@
 
 	<div>
 		<div class=" mb-2 text-sm font-medium">{$i18n.t('Chat Permissions')}</div>
-		<div class="flex flex-col space-y-2">
-			<PermissionSwitch
-				label={$i18n.t('Allow File Upload')}
-				bind:state={permissions.chat.file_upload}
-				defaultState={defaultPermissions?.chat?.file_upload}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Chat Controls')}
-				bind:state={permissions.chat.controls}
-				defaultState={defaultPermissions?.chat?.controls}
-			/>
-
-			{#if permissions.chat.controls}
-				<div class="flex flex-col space-y-2 pl-4">
-					<PermissionSwitch
-						label={$i18n.t('Allow Chat Valves')}
-						bind:state={permissions.chat.valves}
-						defaultState={defaultPermissions?.chat?.valves}
-					/>
-					<PermissionSwitch
-						label={$i18n.t('Allow Chat System Prompt')}
-						bind:state={permissions.chat.system_prompt}
-						defaultState={defaultPermissions?.chat?.system_prompt}
-					/>
-					<PermissionSwitch
-						label={$i18n.t('Allow Chat Params')}
-						bind:state={permissions.chat.params}
-						defaultState={defaultPermissions?.chat?.params}
-					/>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow File Upload')}
+				</div>
+				<Switch bind:state={permissions.chat.file_upload} />
+			</div>
+			{#if defaultPermissions?.chat?.file_upload && !permissions.chat.file_upload}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Chat Controls')}
+				</div>
+				<Switch bind:state={permissions.chat.controls} />
+			</div>
+			{#if defaultPermissions?.chat?.controls && !permissions.chat.controls}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		{#if permissions.chat.controls}
+			<div class="flex flex-col w-full pl-4">
+				<div class="flex w-full justify-between my-2 pr-2">
+					<div class=" self-center text-xs font-medium">
+						{$i18n.t('Allow Chat Valves')}
+					</div>
+					<Switch bind:state={permissions.chat.valves} />
+				</div>
+				{#if defaultPermissions?.chat?.valves && !permissions.chat.valves}
+					<div class="pb-1 pl-1 pr-2 pt-1">
+						<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+							⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+						</div>
+					</div>
+				{/if}
+			</div>
+
+			<div class="flex flex-col w-full pl-4">
+				<div class="flex w-full justify-between my-2 pr-2">
+					<div class=" self-center text-xs font-medium">
+						{$i18n.t('Allow Chat System Prompt')}
+					</div>
+					<Switch bind:state={permissions.chat.system_prompt} />
+				</div>
+				{#if defaultPermissions?.chat?.system_prompt && !permissions.chat.system_prompt}
+					<div class="pb-1 pl-1 pr-2 pt-1">
+						<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+							⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+						</div>
+					</div>
+				{/if}
+			</div>
+
+			<div class="flex flex-col w-full pl-4">
+				<div class="flex w-full justify-between my-2 pr-2">
+					<div class=" self-center text-xs font-medium">
+						{$i18n.t('Allow Chat Params')}
+					</div>
+					<Switch bind:state={permissions.chat.params} />
+				</div>
+				{#if defaultPermissions?.chat?.params && !permissions.chat.params}
+					<div class="pb-1 pl-1 pr-2 pt-1">
+						<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+							⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+						</div>
+					</div>
+				{/if}
+			</div>
+		{/if}
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Chat Edit')}
+				</div>
+				<Switch bind:state={permissions.chat.edit} />
+			</div>
+			{#if defaultPermissions?.chat?.edit && !permissions.chat.edit}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Chat Delete')}
+				</div>
+				<Switch bind:state={permissions.chat.delete} />
+			</div>
+			{#if defaultPermissions?.chat?.delete && !permissions.chat.delete}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Delete Messages')}
+				</div>
+				<Switch bind:state={permissions.chat.delete_message} />
+			</div>
+			{#if defaultPermissions?.chat?.delete_message && !permissions.chat.delete_message}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Continue Response')}
+				</div>
+				<Switch bind:state={permissions.chat.continue_response} />
+			</div>
+			{#if defaultPermissions?.chat?.continue_response && !permissions.chat.continue_response}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Regenerate Response')}
+				</div>
+				<Switch bind:state={permissions.chat.regenerate_response} />
+			</div>
+			{#if defaultPermissions?.chat?.regenerate_response && !permissions.chat.regenerate_response}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Rate Response')}
+				</div>
+				<Switch bind:state={permissions.chat.rate_response} />
+			</div>
+			{#if defaultPermissions?.chat?.rate_response && !permissions.chat.rate_response}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Chat Share')}
+				</div>
+				<Switch bind:state={permissions.chat.share} />
+			</div>
+			{#if defaultPermissions?.chat?.share && !permissions.chat.share}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Chat Export')}
+				</div>
+				<Switch bind:state={permissions.chat.export} />
+			</div>
+			{#if defaultPermissions?.chat?.export && !permissions.chat.export}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Speech to Text')}
+				</div>
+				<Switch bind:state={permissions.chat.stt} />
+			</div>
+			{#if defaultPermissions?.chat?.stt && !permissions.chat.stt}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Text to Speech')}
+				</div>
+				<Switch bind:state={permissions.chat.tts} />
+			</div>
+			{#if defaultPermissions?.chat?.tts && !permissions.chat.tts}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Call')}
+				</div>
+				<Switch bind:state={permissions.chat.call} />
+			</div>
+			{#if defaultPermissions?.chat?.call && !permissions.chat.call}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
 				</div>
 			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Multiple Models in Chat')}
+				</div>
+				<Switch bind:state={permissions.chat.multiple_models} />
+			</div>
+			{#if defaultPermissions?.chat?.multiple_models && !permissions.chat.multiple_models}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
 
-			<PermissionSwitch
-				label={$i18n.t('Allow Chat Edit')}
-				bind:state={permissions.chat.edit}
-				defaultState={defaultPermissions?.chat?.edit}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Chat Delete')}
-				bind:state={permissions.chat.delete}
-				defaultState={defaultPermissions?.chat?.delete}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Delete Messages')}
-				bind:state={permissions.chat.delete_message}
-				defaultState={defaultPermissions?.chat?.delete_message}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Continue Response')}
-				bind:state={permissions.chat.continue_response}
-				defaultState={defaultPermissions?.chat?.continue_response}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Regenerate Response')}
-				bind:state={permissions.chat.regenerate_response}
-				defaultState={defaultPermissions?.chat?.regenerate_response}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Rate Response')}
-				bind:state={permissions.chat.rate_response}
-				defaultState={defaultPermissions?.chat?.rate_response}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Chat Share')}
-				bind:state={permissions.chat.share}
-				defaultState={defaultPermissions?.chat?.share}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Chat Export')}
-				bind:state={permissions.chat.export}
-				defaultState={defaultPermissions?.chat?.export}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Speech to Text')}
-				bind:state={permissions.chat.stt}
-				defaultState={defaultPermissions?.chat?.stt}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Text to Speech')}
-				bind:state={permissions.chat.tts}
-				defaultState={defaultPermissions?.chat?.tts}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Call')}
-				bind:state={permissions.chat.call}
-				defaultState={defaultPermissions?.chat?.call}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Multiple Models in Chat')}
-				bind:state={permissions.chat.multiple_models}
-				defaultState={defaultPermissions?.chat?.multiple_models}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Allow Temporary Chat')}
-				bind:state={permissions.chat.temporary}
-				defaultState={defaultPermissions?.chat?.temporary}
-			/>
-
-			{#if permissions.chat.temporary}
-				<div class="pl-4">
-					<PermissionSwitch
-						label={$i18n.t('Enforce Temporary Chat')}
-						bind:state={permissions.chat.temporary_enforced}
-						defaultState={defaultPermissions?.chat?.temporary_enforced}
-					/>
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Allow Temporary Chat')}
+				</div>
+				<Switch bind:state={permissions.chat.temporary} />
+			</div>
+			{#if defaultPermissions?.chat?.temporary && !permissions.chat.temporary}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
 				</div>
 			{/if}
 		</div>
+
+		{#if permissions.chat.temporary}
+			<div class="flex flex-col w-full pl-4">
+				<div class="flex w-full justify-between my-2 pr-2">
+					<div class=" self-center text-xs font-medium">
+						{$i18n.t('Enforce Temporary Chat')}
+					</div>
+					<Switch bind:state={permissions.chat.temporary_enforced} />
+				</div>
+				{#if defaultPermissions?.chat?.temporary_enforced && !permissions.chat.temporary_enforced}
+					<div class="pb-1 pl-1 pr-2 pt-1">
+						<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+							⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+						</div>
+					</div>
+				{/if}
+			</div>
+		{/if}
 	</div>
 
 	<hr class=" border-gray-100 dark:border-gray-850" />
 
 	<div>
 		<div class=" mb-2 text-sm font-medium">{$i18n.t('Features Permissions')}</div>
-		<div class="flex flex-col space-y-2">
-			<PermissionSwitch
-				label={$i18n.t('Direct Tool Servers')}
-				bind:state={permissions.features.direct_tool_servers}
-				defaultState={defaultPermissions?.features?.direct_tool_servers}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Web Search')}
-				bind:state={permissions.features.web_search}
-				defaultState={defaultPermissions?.features?.web_search}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Image Generation')}
-				bind:state={permissions.features.image_generation}
-				defaultState={defaultPermissions?.features?.image_generation}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Code Interpreter')}
-				bind:state={permissions.features.code_interpreter}
-				defaultState={defaultPermissions?.features?.code_interpreter}
-			/>
-			<PermissionSwitch
-				label={$i18n.t('Notes')}
-				bind:state={permissions.features.notes}
-				defaultState={defaultPermissions?.features?.notes}
-			/>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Direct Tool Servers')}
+				</div>
+				<Switch bind:state={permissions.features.direct_tool_servers} />
+			</div>
+			{#if defaultPermissions?.features?.direct_tool_servers && !permissions.features.direct_tool_servers}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Web Search')}
+				</div>
+				<Switch bind:state={permissions.features.web_search} />
+			</div>
+			{#if defaultPermissions?.features?.web_search && !permissions.features.web_search}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Image Generation')}
+				</div>
+				<Switch bind:state={permissions.features.image_generation} />
+			</div>
+			{#if defaultPermissions?.features?.image_generation && !permissions.features.image_generation}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Code Interpreter')}
+				</div>
+				<Switch bind:state={permissions.features.code_interpreter} />
+			</div>
+			{#if defaultPermissions?.features?.code_interpreter && !permissions.features.code_interpreter}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
+		</div>
+
+		<div class="flex flex-col w-full">
+			<div class="flex w-full justify-between my-2 pr-2">
+				<div class=" self-center text-xs font-medium">
+					{$i18n.t('Notes')}
+				</div>
+				<Switch bind:state={permissions.features.notes} />
+			</div>
+			{#if defaultPermissions?.features?.notes && !permissions.features.notes}
+				<div class="pb-1 pl-1 pr-2 pt-1">
+					<div class="text-xs text-amber-600 dark:text-amber-400 bg-amber-50 dark:bg-amber-900/20 border border-amber-200 dark:border-amber-800 rounded px-2 py-1">
+						⚠️ {$i18n.t('This permission is enabled for the default "user" role and will remain active.')}
+					</div>
+				</div>
+			{/if}
 		</div>
 	</div>
-</div>
+</div>