From a8ac7b8b63b960b6a46c5a6f13b577eb2668434e Mon Sep 17 00:00:00 2001 From: Bryan Liao Date: Thu, 31 Jul 2025 14:25:37 -0700 Subject: [PATCH] Update to match ensemble theme even more --- components.d.ts | 10 +++ src/App.vue | 2 +- src/components/ToolCard.vue | 29 ++++++- src/theme-ensemble.ts | 55 ++++++++++++++ .../json-diff/diff-viewer/diff-viewer.vue | 2 +- src/ui/c-alert/c-alert.theme.ts | 2 +- src/ui/c-button/c-button.theme.ts | 2 +- src/ui/c-button/c-button.vue | 3 +- src/ui/c-card/c-card.vue | 4 + src/ui/c-input-text/c-input-text.theme.ts | 2 +- src/ui/c-input-text/c-input-text.vue | 2 +- src/ui/c-link/c-link.theme.ts | 2 +- src/ui/c-modal/c-modal.theme.ts | 2 +- src/ui/c-select/c-select.theme.ts | 2 +- src/ui/c-select/c-select.vue | 31 ++++++-- src/ui/theme/theme-ensemble.ts | 76 +++++++++++++++++++ 16 files changed, 207 insertions(+), 19 deletions(-) create mode 100644 src/theme-ensemble.ts create mode 100644 src/ui/theme/theme-ensemble.ts diff --git a/components.d.ts b/components.d.ts index 6608f2ba..38ac84bf 100644 --- a/components.d.ts +++ b/components.d.ts @@ -93,17 +93,24 @@ declare module '@vue/runtime-core' { 'IconMdi:brushVariant': typeof import('~icons/mdi/brush-variant')['default'] 'IconMdi:kettleSteamOutline': typeof import('~icons/mdi/kettle-steam-outline')['default'] IconMdiArrowRightBottom: typeof import('~icons/mdi/arrow-right-bottom')['default'] + IconMdiCamera: typeof import('~icons/mdi/camera')['default'] IconMdiChevronDown: typeof import('~icons/mdi/chevron-down')['default'] IconMdiChevronRight: typeof import('~icons/mdi/chevron-right')['default'] IconMdiClose: typeof import('~icons/mdi/close')['default'] IconMdiContentCopy: typeof import('~icons/mdi/content-copy')['default'] + IconMdiDeleteOutline: typeof import('~icons/mdi/delete-outline')['default'] + IconMdiDownload: typeof import('~icons/mdi/download')['default'] IconMdiEye: typeof import('~icons/mdi/eye')['default'] IconMdiEyeOff: typeof import('~icons/mdi/eye-off')['default'] IconMdiHeart: typeof import('~icons/mdi/heart')['default'] + IconMdiPause: typeof import('~icons/mdi/pause')['default'] + IconMdiPlay: typeof import('~icons/mdi/play')['default'] + IconMdiRecord: typeof import('~icons/mdi/record')['default'] IconMdiRefresh: typeof import('~icons/mdi/refresh')['default'] IconMdiSearch: typeof import('~icons/mdi/search')['default'] IconMdiTranslate: typeof import('~icons/mdi/translate')['default'] IconMdiTriangleDown: typeof import('~icons/mdi/triangle-down')['default'] + IconMdiVideo: typeof import('~icons/mdi/video')['default'] InputCopyable: typeof import('./src/components/InputCopyable.vue')['default'] IntegerBaseConverter: typeof import('./src/tools/integer-base-converter/integer-base-converter.vue')['default'] Ipv4AddressConverter: typeof import('./src/tools/ipv4-address-converter/ipv4-address-converter.vue')['default'] @@ -141,6 +148,7 @@ declare module '@vue/runtime-core' { NCollapseTransition: typeof import('naive-ui')['NCollapseTransition'] NColorPicker: typeof import('naive-ui')['NColorPicker'] NConfigProvider: typeof import('naive-ui')['NConfigProvider'] + NDatePicker: typeof import('naive-ui')['NDatePicker'] NDivider: typeof import('naive-ui')['NDivider'] NDynamicInput: typeof import('naive-ui')['NDynamicInput'] NEllipsis: typeof import('naive-ui')['NEllipsis'] @@ -149,6 +157,7 @@ declare module '@vue/runtime-core' { NGi: typeof import('naive-ui')['NGi'] NGrid: typeof import('naive-ui')['NGrid'] NH1: typeof import('naive-ui')['NH1'] + NH2: typeof import('naive-ui')['NH2'] NH3: typeof import('naive-ui')['NH3'] NIcon: typeof import('naive-ui')['NIcon'] NImage: typeof import('naive-ui')['NImage'] @@ -165,6 +174,7 @@ declare module '@vue/runtime-core' { NStatistic: typeof import('naive-ui')['NStatistic'] NSwitch: typeof import('naive-ui')['NSwitch'] NTable: typeof import('naive-ui')['NTable'] + NTag: typeof import('naive-ui')['NTag'] NumeronymGenerator: typeof import('./src/tools/numeronym-generator/numeronym-generator.vue')['default'] OtpCodeGeneratorAndValidator: typeof import('./src/tools/otp-code-generator-and-validator/otp-code-generator-and-validator.vue')['default'] PasswordStrengthAnalyser: typeof import('./src/tools/password-strength-analyser/password-strength-analyser.vue')['default'] diff --git a/src/App.vue b/src/App.vue index 8e65335d..f597ae2b 100644 --- a/src/App.vue +++ b/src/App.vue @@ -1,7 +1,7 @@ + + diff --git a/src/theme-ensemble.ts b/src/theme-ensemble.ts new file mode 100644 index 00000000..7ecaa4bd --- /dev/null +++ b/src/theme-ensemble.ts @@ -0,0 +1,55 @@ +import type { GlobalThemeOverrides } from 'naive-ui'; + +export const lightThemeOverrides: GlobalThemeOverrides = { + Menu: { + itemHeight: '32px', + }, + + Layout: { color: '#f1f5f9' }, + + AutoComplete: { + peers: { + InternalSelectMenu: { height: '500px' }, + }, + }, +}; + +export const darkThemeOverrides: GlobalThemeOverrides = { + common: { + primaryColor: '#2886BB', + primaryColorHover: '#3C98C9', + primaryColorPressed: '#1A5E87', + primaryColorSuppl: '#2886BB', + }, + + Notification: { + color: '#333333', + }, + + AutoComplete: { + peers: { + InternalSelectMenu: { height: '500px', color: '#1e1e1e' }, + }, + }, + + Menu: { + itemHeight: '32px', + }, + + Layout: { + color: '#1c1c1c', + siderColor: '#232323', + siderBorderColor: 'transparent', + }, + + Card: { + color: '#232323', + borderColor: '#282828', + }, + + Table: { + tdColor: '#232323', + thColor: '#353535', + }, + +}; diff --git a/src/tools/json-diff/diff-viewer/diff-viewer.vue b/src/tools/json-diff/diff-viewer/diff-viewer.vue index 1c585df7..2a443a64 100644 --- a/src/tools/json-diff/diff-viewer/diff-viewer.vue +++ b/src/tools/json-diff/diff-viewer/diff-viewer.vue @@ -2,7 +2,7 @@ import _ from 'lodash'; import { diff } from '../json-diff.models'; import { DiffRootViewer } from './diff-viewer.models'; -import { useAppTheme } from '@/ui/theme/themes'; +import { useAppTheme } from '@/ui/theme/theme-ensemble'; const props = defineProps<{ leftJson: unknown; rightJson: unknown }>(); const onlyShowDifferences = ref(false); diff --git a/src/ui/c-alert/c-alert.theme.ts b/src/ui/c-alert/c-alert.theme.ts index 2176a102..5e338be2 100644 --- a/src/ui/c-alert/c-alert.theme.ts +++ b/src/ui/c-alert/c-alert.theme.ts @@ -1,6 +1,6 @@ import { darken } from '../color/color.models'; import { defineThemes } from '../theme/theme.models'; -import { appThemes } from '../theme/themes'; +import { appThemes } from '../theme/theme-ensemble'; import WarningIcon from '~icons/mdi/alert-circle-outline'; import ErrorIcon from '~icons/mdi/close-circle-outline'; diff --git a/src/ui/c-button/c-button.theme.ts b/src/ui/c-button/c-button.theme.ts index 926cd110..2fd958f7 100644 --- a/src/ui/c-button/c-button.theme.ts +++ b/src/ui/c-button/c-button.theme.ts @@ -1,6 +1,6 @@ import { darken, lighten } from '../color/color.models'; import { defineThemes } from '../theme/theme.models'; -import { appThemes } from '../theme/themes'; +import { appThemes } from '../theme/theme-ensemble'; function createState({ textColor, diff --git a/src/ui/c-button/c-button.vue b/src/ui/c-button/c-button.vue index 06a4786d..ce7f94fb 100644 --- a/src/ui/c-button/c-button.vue +++ b/src/ui/c-button/c-button.vue @@ -1,6 +1,6 @@