@keenmate/pure-admin-core 1.0.0-rc06 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +77 -7
- package/dist/css/main.css +1313 -452
- package/package.json +1 -1
- package/snippets/customization.html +1 -1
- package/snippets/layout.html +66 -0
- package/snippets/manifest.json +0 -50
- package/snippets/profile.html +51 -3
- package/src/scss/_base-css-variables.scss +432 -422
- package/src/scss/_core.scss +105 -105
- package/src/scss/_fonts.scss +0 -14
- package/src/scss/_variables.scss +12 -14
- package/src/scss/core-components/_alerts.scss +7 -7
- package/src/scss/core-components/_base.scss +3 -3
- package/src/scss/core-components/_buttons.scss +425 -425
- package/src/scss/core-components/_callouts.scss +139 -139
- package/src/scss/core-components/_cards.scss +321 -321
- package/src/scss/core-components/_checkbox-lists.scss +2 -2
- package/src/scss/core-components/_code.scss +4 -4
- package/src/scss/core-components/_command-palette.scss +518 -518
- package/src/scss/core-components/_comparison.scss +3 -3
- package/src/scss/core-components/_file-selector.scss +780 -780
- package/src/scss/core-components/_forms.scss +16 -16
- package/src/scss/core-components/_grid.scss +25 -0
- package/src/scss/core-components/_layout.scss +15 -15
- package/src/scss/core-components/_lists.scss +7 -7
- package/src/scss/core-components/_logic-tree.scss +280 -280
- package/src/scss/core-components/_modals.scss +2 -2
- package/src/scss/core-components/_notifications.scss +74 -7
- package/src/scss/core-components/_pagers.scss +3 -3
- package/src/scss/core-components/_popconfirm.scss +1 -1
- package/src/scss/core-components/_profile.scss +400 -379
- package/src/scss/core-components/_scrollbars.scss +40 -41
- package/src/scss/core-components/_settings-panel.scss +5 -5
- package/src/scss/core-components/_statistics.scss +6 -6
- package/src/scss/core-components/_tables.scss +566 -566
- package/src/scss/core-components/_tabs.scss +493 -493
- package/src/scss/core-components/_timeline.scss +15 -15
- package/src/scss/core-components/_toasts.scss +4 -4
- package/src/scss/core-components/_tooltips.scss +8 -8
- package/src/scss/core-components/_utilities.scss +35 -30
- package/src/scss/core-components/_web-components-theme.scss +294 -294
- package/src/scss/core-components/badges/_composite-badge-variants.scss +3 -3
- package/src/scss/core-components/badges/_labels.scss +1 -1
- package/src/scss/core-components/forms/_checkboxes-radios.scss +2 -2
- package/src/scss/core-components/forms/_form-inputs.scss +4 -4
- package/src/scss/core-components/forms/_form-layout.scss +2 -2
- package/src/scss/core-components/forms/_form-states.scss +1 -1
- package/src/scss/core-components/forms/_input-groups.scss +13 -11
- package/src/scss/core-components/forms/_input-wrapper.scss +1 -1
- package/src/scss/core-components/forms/_query-editor.scss +17 -17
- package/src/scss/core-components/layout/_layout-container.scss +33 -1
- package/src/scss/core-components/layout/_navbar-elements.scss +1 -1
- package/src/scss/core-components/layout/_sidebar.scss +53 -2
- package/src/scss/utilities.scss +81 -2
- package/src/scss/variables/_base.scss +20 -10
- package/src/scss/variables/_colors.scss +7 -6
- package/src/scss/variables/_components.scss +8 -11
- package/src/scss/variables/_index.scss +11 -7
- package/src/scss/variables/_spacing.scss +12 -0
- package/src/scss/variables/_typography.scss +2 -2
- package/dist/fonts/Delivery/Delivery_W_Bd.woff2 +0 -0
- package/dist/fonts/Delivery/Delivery_W_BdIt.woff2 +0 -0
- package/dist/fonts/Delivery/Delivery_W_CdBlk.woff2 +0 -0
- package/dist/fonts/Delivery/Delivery_W_CdLt.woff2 +0 -0
- package/dist/fonts/Delivery/Delivery_W_It.woff2 +0 -0
- package/dist/fonts/Delivery/Delivery_W_Lt.woff2 +0 -0
- package/dist/fonts/Delivery/Delivery_W_LtIt.woff2 +0 -0
- package/dist/fonts/Delivery/Delivery_W_Rg.woff2 +0 -0
- package/src/scss/themes/_dark-base.scss +0 -207
- package/src/scss/themes/audi-light.scss +0 -341
- package/src/scss/themes/audi.scss +0 -303
- package/src/scss/themes/corporate.scss +0 -229
- package/src/scss/themes/dark-blue.scss +0 -165
- package/src/scss/themes/dark-green.scss +0 -169
- package/src/scss/themes/dark-red.scss +0 -173
- package/src/scss/themes/dark.scss +0 -158
- package/src/scss/themes/express.scss +0 -294
- package/src/scss/themes/minimal.scss +0 -134
|
@@ -1,303 +0,0 @@
|
|
|
1
|
-
/* Pure Admin Visual - Audi Theme (Pure SCSS Variables) */
|
|
2
|
-
@use 'sass:color';
|
|
3
|
-
|
|
4
|
-
// =============================================================================
|
|
5
|
-
// THEME COLOR SLOTS (1-9) - Audi-inspired palette
|
|
6
|
-
// =============================================================================
|
|
7
|
-
$color-1: #bb0a30; // Audi Red (classic)
|
|
8
|
-
$color-2: #ff4444; // Light Red
|
|
9
|
-
$color-3: #ff6600; // Orange (warning tone)
|
|
10
|
-
$color-4: #d4af37; // Gold (premium)
|
|
11
|
-
$color-5: #00a0a0; // Teal (contrast)
|
|
12
|
-
$color-6: #0066cc; // Blue (professional)
|
|
13
|
-
$color-7: #8c8c8c; // Silver (metallic)
|
|
14
|
-
$color-8: #404040; // Charcoal (neutral)
|
|
15
|
-
$color-9: #6b3fa0; // Purple (luxury)
|
|
16
|
-
|
|
17
|
-
// 1. Import framework variables first (all defaults with !default flags)
|
|
18
|
-
@import '../variables';
|
|
19
|
-
|
|
20
|
-
// 2. Override SCSS variables for Audi theme
|
|
21
|
-
$sidebar-width: 29rem; // 290px (10px base)
|
|
22
|
-
$border-radius: 1px;
|
|
23
|
-
$border-radius-lg: 2px;
|
|
24
|
-
|
|
25
|
-
// Audi color palette
|
|
26
|
-
$audi-black: #000000; // Pure black
|
|
27
|
-
$audi-near-black: #0a0a0a; // Near black
|
|
28
|
-
$audi-dark: #1a1a1a; // Dark gray
|
|
29
|
-
$audi-gray: #2a2a2a; // Medium gray
|
|
30
|
-
$audi-gray-light: #333333; // Light gray
|
|
31
|
-
$audi-gray-lighter: #4d4d4d; // Lighter gray
|
|
32
|
-
$audi-gray-lightest: #666666;// Lightest gray
|
|
33
|
-
$audi-red: #ff0000; // Signature red
|
|
34
|
-
$audi-red-dark: #cc0000; // Dark red
|
|
35
|
-
|
|
36
|
-
// Audi theme colors - Sharp black/red German aesthetic
|
|
37
|
-
$primary-bg: $audi-near-black;
|
|
38
|
-
$bg-secondary: $audi-near-black;
|
|
39
|
-
$content-background-color: $audi-dark; // Settings panel and main content background
|
|
40
|
-
$header-bg: $audi-black;
|
|
41
|
-
$header-border-color: $audi-gray-light; // Match sidebar border color
|
|
42
|
-
$sidebar-bg: $audi-dark;
|
|
43
|
-
$sidebar-submenu-bg: $audi-gray-light;
|
|
44
|
-
$sidebar-submenu-hover-bg: rgba($audi-red, 0.25); // Match level 1 hover (red accent)
|
|
45
|
-
$sidebar-submenu-active-bg: rgba($audi-red, 0.3); // Match level 1 active (red accent)
|
|
46
|
-
$footer-bg: $audi-black;
|
|
47
|
-
$border-color: $audi-gray-light;
|
|
48
|
-
$text-primary: #ffffff;
|
|
49
|
-
$text-secondary: #cccccc;
|
|
50
|
-
$accent-color: $audi-red;
|
|
51
|
-
$accent-hover: rgba($audi-red, 0.3); // For active/selected state
|
|
52
|
-
$accent-light: rgba($audi-red, 0.25); // For hover state - increased for better visibility on dark bg
|
|
53
|
-
|
|
54
|
-
// Sync base variables with theme colors (for web components)
|
|
55
|
-
// Colors
|
|
56
|
-
$base-accent-color: $accent-color;
|
|
57
|
-
$base-accent-color-hover: color.adjust($base-accent-color, $lightness: 10%);
|
|
58
|
-
$base-accent-color-active: color.adjust($base-accent-color, $lightness: 20%);
|
|
59
|
-
$base-accent-color-light: $accent-light;
|
|
60
|
-
$base-accent-color-light-hover: rgba($base-accent-color, 0.3);
|
|
61
|
-
$base-primary-bg: $audi-dark;
|
|
62
|
-
$base-primary-bg-hover: $audi-gray;
|
|
63
|
-
$base-text-color-1: #ffffff;
|
|
64
|
-
$base-text-color-2: #cccccc;
|
|
65
|
-
$base-text-color-3: #999999;
|
|
66
|
-
$base-text-color-4: #666666;
|
|
67
|
-
$base-text-on-accent: #ffffff;
|
|
68
|
-
$base-border-color: $audi-gray-light;
|
|
69
|
-
|
|
70
|
-
// Input fields
|
|
71
|
-
$base-input-background: $audi-black;
|
|
72
|
-
$base-input-color: #ffffff;
|
|
73
|
-
$base-input-border: 1px solid $audi-gray-light;
|
|
74
|
-
$base-input-border-hover: 1px solid $accent-color;
|
|
75
|
-
$base-input-border-focus: 1px solid $accent-color;
|
|
76
|
-
$base-input-placeholder-color: #666666;
|
|
77
|
-
$base-input-background-disabled: rgba($audi-gray, 0.5);
|
|
78
|
-
|
|
79
|
-
// Dropdown/Popover
|
|
80
|
-
$base-dropdown-background: $audi-dark;
|
|
81
|
-
$base-dropdown-border: 1px solid $audi-gray-light;
|
|
82
|
-
$base-dropdown-box-shadow: 0 8px 16px rgba(0, 0, 0, 0.4);
|
|
83
|
-
|
|
84
|
-
// Tooltip
|
|
85
|
-
$base-tooltip-background: $audi-gray-light;
|
|
86
|
-
$base-tooltip-text-color: #ffffff;
|
|
87
|
-
|
|
88
|
-
// Form focus colors - must match accent color
|
|
89
|
-
$input-focus-border-color: $accent-color;
|
|
90
|
-
$select-focus-border-color: $accent-color;
|
|
91
|
-
$textarea-focus-border-color: $accent-color;
|
|
92
|
-
|
|
93
|
-
// Checkbox colors - must match accent color
|
|
94
|
-
$checkbox-border-color-hover: $accent-color;
|
|
95
|
-
$checkbox-border-color-checked: $accent-color;
|
|
96
|
-
$checkbox-bg-checked: $accent-color;
|
|
97
|
-
$checkbox-bg-indeterminate: $accent-color;
|
|
98
|
-
$checkbox-focus-shadow: 0 0 0 2px rgba($accent-color, 0.25);
|
|
99
|
-
|
|
100
|
-
// Card colors
|
|
101
|
-
$card-bg: $audi-dark;
|
|
102
|
-
$card-header-bg: $audi-black;
|
|
103
|
-
$card-footer-bg: $audi-black;
|
|
104
|
-
$card-tabs-bg: $audi-gray-light;
|
|
105
|
-
|
|
106
|
-
// Input colors
|
|
107
|
-
$input-bg: $audi-black;
|
|
108
|
-
$input-border: $audi-gray-light;
|
|
109
|
-
$input-text: #ffffff;
|
|
110
|
-
|
|
111
|
-
// Multiselect dropdown colors (match dark theme)
|
|
112
|
-
$multiselect-dropdown-bg: $audi-dark;
|
|
113
|
-
$multiselect-dropdown-border: $audi-gray-light;
|
|
114
|
-
$multiselect-dropdown-text: #ffffff;
|
|
115
|
-
|
|
116
|
-
// Table colors
|
|
117
|
-
$table-stripe: $audi-gray; // Subtle stripe with medium gray
|
|
118
|
-
$table-bg: $audi-dark;
|
|
119
|
-
$table-header-bg: $audi-black;
|
|
120
|
-
$table-hover-bg: $audi-gray-light;
|
|
121
|
-
|
|
122
|
-
// Enable red accent on table row hover (Audi signature detail)
|
|
123
|
-
$table-hover-accent-width: 0.3rem; // 3px in 10px base
|
|
124
|
-
$table-hover-accent-color: $accent-color; // Uses the red #ff0000
|
|
125
|
-
$table-hover-accent-position: left;
|
|
126
|
-
|
|
127
|
-
// Modal colors
|
|
128
|
-
$modal-content-bg: $audi-dark;
|
|
129
|
-
$modal-overlay-bg: rgba($audi-black, 0.8);
|
|
130
|
-
|
|
131
|
-
// Profile name in header
|
|
132
|
-
$header-profile-name-color: #ffffff; // White text on black header
|
|
133
|
-
|
|
134
|
-
// Button colors - German precision with red accents
|
|
135
|
-
$btn-primary-bg: $audi-red;
|
|
136
|
-
$btn-primary-bg-hover: $audi-red-dark;
|
|
137
|
-
$btn-primary-text: #ffffff;
|
|
138
|
-
$btn-secondary-bg: $audi-gray-light;
|
|
139
|
-
$btn-secondary-bg-hover: $audi-gray-lighter;
|
|
140
|
-
$btn-secondary-text: #ffffff;
|
|
141
|
-
$btn-success-bg: #00cc44;
|
|
142
|
-
$btn-success-bg-hover: #009933;
|
|
143
|
-
$btn-success-text: #ffffff;
|
|
144
|
-
$btn-danger-bg: $audi-red;
|
|
145
|
-
$btn-danger-bg-hover: $audi-red-dark;
|
|
146
|
-
$btn-danger-text: #ffffff;
|
|
147
|
-
$btn-warning-bg: #ff6600;
|
|
148
|
-
$btn-warning-bg-hover: #e55a00;
|
|
149
|
-
$btn-warning-text: #ffffff;
|
|
150
|
-
$btn-info-bg: #0099ff;
|
|
151
|
-
$btn-info-bg-hover: #0077cc;
|
|
152
|
-
$btn-info-text: #ffffff;
|
|
153
|
-
$btn-light-bg: $audi-gray-lightest;
|
|
154
|
-
$btn-light-bg-hover: #808080;
|
|
155
|
-
$btn-light-text: #ffffff;
|
|
156
|
-
$btn-dark-bg: $audi-black;
|
|
157
|
-
$btn-dark-bg-hover: $audi-dark;
|
|
158
|
-
$btn-dark-text: #ffffff;
|
|
159
|
-
|
|
160
|
-
// Validation shadow colors - match button colors
|
|
161
|
-
$success-bg: $btn-success-bg;
|
|
162
|
-
$success-bg-light: rgba(0, 204, 68, 0.25);
|
|
163
|
-
$warning-bg: $btn-warning-bg;
|
|
164
|
-
$warning-bg-light: rgba(255, 102, 0, 0.25);
|
|
165
|
-
$danger-bg: $btn-danger-bg;
|
|
166
|
-
$danger-bg-light: rgba(255, 0, 0, 0.25);
|
|
167
|
-
|
|
168
|
-
// 3. Add Fira Sans Condensed fonts
|
|
169
|
-
/* cyrillic-ext */
|
|
170
|
-
@font-face {
|
|
171
|
-
font-family: 'Fira Sans Condensed';
|
|
172
|
-
font-style: normal;
|
|
173
|
-
font-weight: 400;
|
|
174
|
-
font-display: swap;
|
|
175
|
-
src: url(/fonts/google/wEOhEADFm8hSaQTFG18FErVhsC9x-tarUfvtrftV.woff2) format('woff2');
|
|
176
|
-
unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
|
|
177
|
-
}
|
|
178
|
-
/* cyrillic */
|
|
179
|
-
@font-face {
|
|
180
|
-
font-family: 'Fira Sans Condensed';
|
|
181
|
-
font-style: normal;
|
|
182
|
-
font-weight: 400;
|
|
183
|
-
font-display: swap;
|
|
184
|
-
src: url(/fonts/google/wEOhEADFm8hSaQTFG18FErVhsC9x-tarUfLtrftV.woff2) format('woff2');
|
|
185
|
-
unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
|
|
186
|
-
}
|
|
187
|
-
/* greek-ext */
|
|
188
|
-
@font-face {
|
|
189
|
-
font-family: 'Fira Sans Condensed';
|
|
190
|
-
font-style: normal;
|
|
191
|
-
font-weight: 400;
|
|
192
|
-
font-display: swap;
|
|
193
|
-
src: url(/fonts/google/wEOhEADFm8hSaQTFG18FErVhsC9x-tarUfrtrftV.woff2) format('woff2');
|
|
194
|
-
unicode-range: U+1F00-1FFF;
|
|
195
|
-
}
|
|
196
|
-
/* greek */
|
|
197
|
-
@font-face {
|
|
198
|
-
font-family: 'Fira Sans Condensed';
|
|
199
|
-
font-style: normal;
|
|
200
|
-
font-weight: 400;
|
|
201
|
-
font-display: swap;
|
|
202
|
-
src: url(/fonts/google/wEOhEADFm8hSaQTFG18FErVhsC9x-tarUfXtrftV.woff2) format('woff2');
|
|
203
|
-
unicode-range: U+0370-03FF;
|
|
204
|
-
}
|
|
205
|
-
/* vietnamese */
|
|
206
|
-
@font-face {
|
|
207
|
-
font-family: 'Fira Sans Condensed';
|
|
208
|
-
font-style: normal;
|
|
209
|
-
font-weight: 400;
|
|
210
|
-
font-display: swap;
|
|
211
|
-
src: url(/fonts/google/wEOhEADFm8hSaQTFG18FErVhsC9x-tarUfntrftV.woff2) format('woff2');
|
|
212
|
-
unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+1EA0-1EF9, U+20AB;
|
|
213
|
-
}
|
|
214
|
-
/* latin-ext */
|
|
215
|
-
@font-face {
|
|
216
|
-
font-family: 'Fira Sans Condensed';
|
|
217
|
-
font-style: normal;
|
|
218
|
-
font-weight: 400;
|
|
219
|
-
font-display: swap;
|
|
220
|
-
src: url(/fonts/google/wEOhEADFm8hSaQTFG18FErVhsC9x-tarUfjtrftV.woff2) format('woff2');
|
|
221
|
-
unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
|
|
222
|
-
}
|
|
223
|
-
/* latin */
|
|
224
|
-
@font-face {
|
|
225
|
-
font-family: 'Fira Sans Condensed';
|
|
226
|
-
font-style: normal;
|
|
227
|
-
font-weight: 400;
|
|
228
|
-
font-display: swap;
|
|
229
|
-
src: url(/fonts/google/wEOhEADFm8hSaQTFG18FErVhsC9x-tarUfbtrQ.woff2) format('woff2');
|
|
230
|
-
unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
// 4. Override font family SCSS variable after fonts are defined
|
|
234
|
-
$body-font-family: "Fira Sans Condensed", "Arial Narrow", "Arial", sans-serif;
|
|
235
|
-
|
|
236
|
-
// Card styling - thicker border for Audi design language
|
|
237
|
-
$card-border-width: $border-width-medium;
|
|
238
|
-
$card-border-radius: 0; // Sharp edges
|
|
239
|
-
|
|
240
|
-
// 5. Import core framework styles (will use all our SCSS variables)
|
|
241
|
-
@import '../core';
|
|
242
|
-
|
|
243
|
-
// 5b. Import utility classes
|
|
244
|
-
@import '../utilities';
|
|
245
|
-
@import '../base-css-variables';
|
|
246
|
-
|
|
247
|
-
// 6. Audi-specific styling overrides
|
|
248
|
-
.pa-btn--primary {
|
|
249
|
-
font-weight: $font-weight-bold;
|
|
250
|
-
color: #ffffff !important; // Ensure white text on red background
|
|
251
|
-
border-radius: 0 !important; // Sharp edges for German precision
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
.pa-btn--danger {
|
|
255
|
-
font-weight: $font-weight-bold;
|
|
256
|
-
text-transform: uppercase;
|
|
257
|
-
color: #ffffff !important; // Ensure white text on red background
|
|
258
|
-
border-radius: 0 !important; // Sharp edges for German precision
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
.pa-btn--secondary {
|
|
262
|
-
border-color: $audi-gray-lightest !important; // Lighter border for better visibility
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
.pa-btn--outline-secondary {
|
|
266
|
-
border-color: $audi-gray-lightest !important; // Lighter border for dark background
|
|
267
|
-
color: #cccccc !important; // Lighter text for dark background
|
|
268
|
-
|
|
269
|
-
&:hover {
|
|
270
|
-
background-color: $audi-gray-light !important;
|
|
271
|
-
color: #ffffff !important;
|
|
272
|
-
}
|
|
273
|
-
}
|
|
274
|
-
|
|
275
|
-
.pa-card {
|
|
276
|
-
box-shadow: 0 $spacing-xs ($spacing-sm * 2) rgba($audi-black, 0.8);
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
// Sidebar left-border accent (instead of default right-border)
|
|
280
|
-
.pa-sidebar__link {
|
|
281
|
-
border-left: $border-width-thick solid transparent; // Reserve space for active state
|
|
282
|
-
border-right: none; // Remove default right border reservation
|
|
283
|
-
}
|
|
284
|
-
|
|
285
|
-
.pa-sidebar__link--active {
|
|
286
|
-
border-left-color: $accent-color !important;
|
|
287
|
-
color: $accent-color !important;
|
|
288
|
-
}
|
|
289
|
-
|
|
290
|
-
.pa-sidebar__link--active .pa-sidebar__label,
|
|
291
|
-
.pa-sidebar__link--active .pa-sidebar__icon {
|
|
292
|
-
color: $accent-color !important;
|
|
293
|
-
}
|
|
294
|
-
|
|
295
|
-
// CSS Variables for page loader (FOUC prevention) and base theme variables
|
|
296
|
-
:root {
|
|
297
|
-
--page-loader-bg: rgba(10, 10, 10, 0.95);
|
|
298
|
-
--page-loader-spinner-border: #333;
|
|
299
|
-
--page-loader-spinner-accent: #ff0000; // Audi red
|
|
300
|
-
|
|
301
|
-
// Base CSS variables for web components (daterangepicker, multiselect, etc.)
|
|
302
|
-
@include output-base-css-variables;
|
|
303
|
-
}
|
|
@@ -1,229 +0,0 @@
|
|
|
1
|
-
/* Corporate Theme for Pure Admin Visual - Professional blue/gray palette */
|
|
2
|
-
|
|
3
|
-
// =============================================================================
|
|
4
|
-
// THEME COLOR SLOTS (1-9) - Corporate professional palette
|
|
5
|
-
// =============================================================================
|
|
6
|
-
$color-1: #0284c7; // Corporate Blue (primary)
|
|
7
|
-
$color-2: #0ea5e9; // Sky Blue (lighter)
|
|
8
|
-
$color-3: #10b981; // Emerald (success)
|
|
9
|
-
$color-4: #f59e0b; // Amber (attention)
|
|
10
|
-
$color-5: #6366f1; // Indigo (accent)
|
|
11
|
-
$color-6: #8b5cf6; // Violet (creative)
|
|
12
|
-
$color-7: #64748b; // Slate (neutral)
|
|
13
|
-
$color-8: #334155; // Dark Slate (contrast)
|
|
14
|
-
$color-9: #ec4899; // Pink (highlight)
|
|
15
|
-
|
|
16
|
-
@import '../variables';
|
|
17
|
-
|
|
18
|
-
// Corporate color palette
|
|
19
|
-
$corporate-slate-50: #f8fafc;
|
|
20
|
-
$corporate-slate-100: #f1f5f9;
|
|
21
|
-
$corporate-slate-200: #e2e8f0;
|
|
22
|
-
$corporate-slate-300: #cbd5e1;
|
|
23
|
-
$corporate-slate-400: #94a3b8;
|
|
24
|
-
$corporate-slate-500: #64748b;
|
|
25
|
-
$corporate-slate-600: #475569;
|
|
26
|
-
$corporate-slate-700: #334155;
|
|
27
|
-
$corporate-slate-800: #1e293b;
|
|
28
|
-
$corporate-slate-900: #0f172a;
|
|
29
|
-
|
|
30
|
-
$corporate-blue-500: #0ea5e9; // Brighter, more vibrant blue
|
|
31
|
-
$corporate-blue-600: #0284c7;
|
|
32
|
-
$corporate-blue-700: #0369a1;
|
|
33
|
-
|
|
34
|
-
$corporate-gray-50: #f9fafb;
|
|
35
|
-
$corporate-gray-100: #f3f4f6;
|
|
36
|
-
$corporate-gray-200: #e5e7eb;
|
|
37
|
-
$corporate-gray-400: #9ca3af;
|
|
38
|
-
$corporate-gray-500: #6b7280;
|
|
39
|
-
$corporate-gray-600: #4b5563;
|
|
40
|
-
$corporate-gray-700: #374151;
|
|
41
|
-
$corporate-gray-800: #1f2937;
|
|
42
|
-
|
|
43
|
-
$corporate-emerald-500: #10b981;
|
|
44
|
-
$corporate-emerald-600: #059669;
|
|
45
|
-
$corporate-amber-500: #f59e0b;
|
|
46
|
-
$corporate-red-500: #ef4444;
|
|
47
|
-
$corporate-red-600: #dc2626;
|
|
48
|
-
$corporate-cyan-500: #06b6d4;
|
|
49
|
-
$corporate-cyan-600: #0891b2;
|
|
50
|
-
|
|
51
|
-
// Layout overrides
|
|
52
|
-
$footer-height: 3.2rem; // 32px (10px base) - was 2rem at 16px base
|
|
53
|
-
$sidebar-width: 29rem; // 290px (10px base)
|
|
54
|
-
|
|
55
|
-
// Corporate theme color overrides
|
|
56
|
-
$primary-bg: #f4f6f9;
|
|
57
|
-
$content-background-color: #f4f6f9;
|
|
58
|
-
$header-bg: $corporate-slate-800;
|
|
59
|
-
$header-border-color: $corporate-slate-200; // Match sidebar border color
|
|
60
|
-
$header-profile-name-color: #ffffff; // Light text on dark header
|
|
61
|
-
$sidebar-bg: $corporate-slate-50;
|
|
62
|
-
$footer-bg: $corporate-slate-800;
|
|
63
|
-
$border-color: $corporate-slate-200;
|
|
64
|
-
$text-primary: $corporate-slate-700;
|
|
65
|
-
$text-secondary: $corporate-slate-500;
|
|
66
|
-
$accent-color: $corporate-blue-500;
|
|
67
|
-
$accent-hover: rgba(59, 130, 246, 0.1);
|
|
68
|
-
$accent-light: rgba(59, 130, 246, 0.05);
|
|
69
|
-
|
|
70
|
-
// Sync base variables with theme colors
|
|
71
|
-
$base-accent-color: $accent-color;
|
|
72
|
-
$base-accent-color-hover: $corporate-blue-600;
|
|
73
|
-
$base-accent-color-active: $corporate-blue-700;
|
|
74
|
-
$base-accent-color-light: $accent-light;
|
|
75
|
-
$base-accent-color-light-hover: rgba($base-accent-color, 0.08);
|
|
76
|
-
|
|
77
|
-
// Form focus colors - must match accent color
|
|
78
|
-
$input-focus-border-color: $accent-color;
|
|
79
|
-
$select-focus-border-color: $accent-color;
|
|
80
|
-
$textarea-focus-border-color: $accent-color;
|
|
81
|
-
|
|
82
|
-
// Checkbox colors - must match accent color
|
|
83
|
-
$checkbox-border-color-hover: $accent-color;
|
|
84
|
-
$checkbox-border-color-checked: $accent-color;
|
|
85
|
-
$checkbox-bg-checked: $accent-color;
|
|
86
|
-
$checkbox-bg-indeterminate: $accent-color;
|
|
87
|
-
$checkbox-focus-shadow: 0 0 0 2px rgba($accent-color, 0.25);
|
|
88
|
-
|
|
89
|
-
// Card colors
|
|
90
|
-
$card-bg: #ffffff;
|
|
91
|
-
$card-header-bg: $corporate-slate-100;
|
|
92
|
-
$card-footer-bg: $corporate-slate-50;
|
|
93
|
-
$card-tabs-bg: $corporate-slate-200;
|
|
94
|
-
|
|
95
|
-
// Input colors
|
|
96
|
-
$input-bg: #ffffff;
|
|
97
|
-
$input-border: $corporate-slate-200;
|
|
98
|
-
$input-text: $corporate-slate-700;
|
|
99
|
-
|
|
100
|
-
// Table colors
|
|
101
|
-
$table-bg: #ffffff;
|
|
102
|
-
$table-header-bg: $corporate-slate-100;
|
|
103
|
-
$table-hover-bg: $corporate-slate-50;
|
|
104
|
-
$table-stripe: $corporate-slate-50;
|
|
105
|
-
|
|
106
|
-
// Button colors - professional blue/gray palette
|
|
107
|
-
$btn-primary-bg: $corporate-blue-500;
|
|
108
|
-
$btn-primary-bg-hover: $corporate-blue-600;
|
|
109
|
-
$btn-secondary-bg: $corporate-gray-500;
|
|
110
|
-
$btn-secondary-bg-hover: $corporate-gray-600;
|
|
111
|
-
$btn-success-bg: $corporate-emerald-500;
|
|
112
|
-
$btn-success-bg-hover: $corporate-emerald-600;
|
|
113
|
-
$btn-warning-bg: $corporate-amber-500;
|
|
114
|
-
$btn-warning-text: #ffffff;
|
|
115
|
-
$btn-danger-bg: $corporate-red-500;
|
|
116
|
-
$btn-danger-bg-hover: $corporate-red-600;
|
|
117
|
-
$btn-info-bg: $corporate-cyan-500;
|
|
118
|
-
$btn-info-bg-hover: $corporate-cyan-600;
|
|
119
|
-
$btn-light-bg: $corporate-gray-100;
|
|
120
|
-
$btn-light-text: $corporate-gray-700;
|
|
121
|
-
$btn-light-bg-hover: $corporate-gray-200;
|
|
122
|
-
$btn-dark-bg: $corporate-gray-700;
|
|
123
|
-
$btn-dark-bg-hover: $corporate-gray-800;
|
|
124
|
-
|
|
125
|
-
// Validation shadow colors - match button colors
|
|
126
|
-
$success-bg: $btn-success-bg;
|
|
127
|
-
$success-bg-light: rgba(16, 185, 129, 0.1);
|
|
128
|
-
$warning-bg: $btn-warning-bg;
|
|
129
|
-
$warning-bg-light: rgba(245, 158, 11, 0.1);
|
|
130
|
-
$danger-bg: $btn-danger-bg;
|
|
131
|
-
$danger-bg-light: rgba(239, 68, 68, 0.1);
|
|
132
|
-
|
|
133
|
-
// Modal colors
|
|
134
|
-
$modal-overlay-bg: rgba(30, 41, 59, 0.5);
|
|
135
|
-
$modal-content-bg: #ffffff;
|
|
136
|
-
|
|
137
|
-
@import '../core';
|
|
138
|
-
@import '../utilities';
|
|
139
|
-
@import '../base-css-variables';
|
|
140
|
-
|
|
141
|
-
// Corporate-specific styling overrides
|
|
142
|
-
// Header text visibility - light text on dark header
|
|
143
|
-
.pa-header {
|
|
144
|
-
&__brand h1 {
|
|
145
|
-
color: #ffffff !important;
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
&__nav > ul > li > a {
|
|
149
|
-
color: $corporate-slate-300 !important;
|
|
150
|
-
|
|
151
|
-
&:hover {
|
|
152
|
-
color: $corporate-blue-500 !important;
|
|
153
|
-
background-color: rgba($corporate-blue-500, 0.1) !important;
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
// Dropdown menu items - dark text on light background
|
|
158
|
-
&__dropdown li a {
|
|
159
|
-
color: $corporate-slate-700 !important;
|
|
160
|
-
|
|
161
|
-
&:hover {
|
|
162
|
-
color: $corporate-blue-500 !important;
|
|
163
|
-
background-color: rgba($corporate-blue-500, 0.1) !important;
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
&__title h2 {
|
|
168
|
-
color: $corporate-slate-300 !important;
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
&__profile-btn {
|
|
172
|
-
color: #ffffff !important;
|
|
173
|
-
|
|
174
|
-
&:hover {
|
|
175
|
-
background-color: rgba($corporate-blue-500, 0.2) !important;
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
// Burger menu - light bars on dark header
|
|
181
|
-
.burger-menu {
|
|
182
|
-
span {
|
|
183
|
-
background-color: #ffffff !important;
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
&:hover span {
|
|
187
|
-
background-color: $corporate-blue-500 !important;
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
// Theme switcher in header
|
|
192
|
-
.theme-switcher {
|
|
193
|
-
label {
|
|
194
|
-
color: $corporate-slate-300 !important;
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
select {
|
|
198
|
-
background-color: $corporate-slate-700 !important;
|
|
199
|
-
color: #ffffff !important;
|
|
200
|
-
border-color: $corporate-slate-600 !important;
|
|
201
|
-
|
|
202
|
-
&:focus {
|
|
203
|
-
border-color: $corporate-blue-500 !important;
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
// Footer - light text on dark background
|
|
209
|
-
.pa-layout__footer {
|
|
210
|
-
color: $corporate-slate-300;
|
|
211
|
-
|
|
212
|
-
a {
|
|
213
|
-
color: #ffffff;
|
|
214
|
-
|
|
215
|
-
&:hover {
|
|
216
|
-
color: $corporate-blue-500;
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
// CSS Variables for page loader (FOUC prevention) and base theme variables
|
|
222
|
-
:root {
|
|
223
|
-
--page-loader-bg: rgba(26, 26, 26, 0.95);
|
|
224
|
-
--page-loader-spinner-border: #333;
|
|
225
|
-
--page-loader-spinner-accent: #0066cc;
|
|
226
|
-
|
|
227
|
-
// Base CSS variables for web components (daterangepicker, multiselect, etc.)
|
|
228
|
-
@include output-base-css-variables;
|
|
229
|
-
}
|
|
@@ -1,165 +0,0 @@
|
|
|
1
|
-
/* Dark Blue Theme for Pure Admin Visual */
|
|
2
|
-
@use 'sass:color';
|
|
3
|
-
|
|
4
|
-
// =============================================================================
|
|
5
|
-
// THEME COLOR SLOTS (1-9) - Dark blue palette
|
|
6
|
-
// =============================================================================
|
|
7
|
-
$color-1: #3b82f6; // Blue 500 (primary)
|
|
8
|
-
$color-2: #60a5fa; // Blue 400 (lighter)
|
|
9
|
-
$color-3: #22c55e; // Green 500 (success)
|
|
10
|
-
$color-4: #eab308; // Yellow 500 (warning)
|
|
11
|
-
$color-5: #a855f7; // Purple 500 (accent)
|
|
12
|
-
$color-6: #06b6d4; // Cyan 500 (info)
|
|
13
|
-
$color-7: #94a3b8; // Slate 400 (neutral)
|
|
14
|
-
$color-8: #f1f5f9; // Slate 100 (light)
|
|
15
|
-
$color-9: #f43f5e; // Rose 500 (highlight)
|
|
16
|
-
|
|
17
|
-
@import '../variables';
|
|
18
|
-
|
|
19
|
-
// Dark blue theme color palette
|
|
20
|
-
$dark-blue-slate-900: #0f172a;
|
|
21
|
-
$dark-blue-slate-800: #1e293b;
|
|
22
|
-
$dark-blue-slate-700: #334155;
|
|
23
|
-
$dark-blue-slate-600: #475569;
|
|
24
|
-
$dark-blue-slate-100: #f1f5f9;
|
|
25
|
-
$dark-blue-slate-400: #94a3b8;
|
|
26
|
-
|
|
27
|
-
$dark-blue-blue-500: #3b82f6;
|
|
28
|
-
$dark-blue-blue-700: #1e40af;
|
|
29
|
-
$dark-blue-blue-800: #1e3a8a;
|
|
30
|
-
$dark-blue-sky-900: #0c4a6e;
|
|
31
|
-
$dark-blue-sky-800: #075985;
|
|
32
|
-
$dark-blue-sky-700: #0369a1;
|
|
33
|
-
$dark-blue-sky-600: #0284c7;
|
|
34
|
-
$dark-blue-cyan-600: #0e7490;
|
|
35
|
-
$dark-blue-cyan-700: #155e75;
|
|
36
|
-
$dark-blue-sky-50: #e0f2fe;
|
|
37
|
-
$dark-blue-slate-950: #020617;
|
|
38
|
-
|
|
39
|
-
// Color overrides for dark blue theme
|
|
40
|
-
$primary-bg: $dark-blue-slate-900;
|
|
41
|
-
$content-background-color: $dark-blue-slate-900;
|
|
42
|
-
$header-bg: $dark-blue-slate-800;
|
|
43
|
-
$sidebar-bg: $dark-blue-slate-800;
|
|
44
|
-
$sidebar-submenu-bg: $dark-blue-slate-700;
|
|
45
|
-
$sidebar-submenu-hover-bg: $dark-blue-slate-600;
|
|
46
|
-
$sidebar-submenu-active-bg: $dark-blue-slate-700;
|
|
47
|
-
$footer-bg: $dark-blue-slate-800;
|
|
48
|
-
$border-color: $dark-blue-slate-700;
|
|
49
|
-
$header-border-color: $dark-blue-slate-700; // Match sidebar border color
|
|
50
|
-
$text-primary: $dark-blue-slate-100;
|
|
51
|
-
$text-secondary: $dark-blue-slate-400;
|
|
52
|
-
$accent-color: $dark-blue-blue-500;
|
|
53
|
-
$accent-hover: rgba(59, 130, 246, 0.15);
|
|
54
|
-
$accent-light: rgba(59, 130, 246, 0.08);
|
|
55
|
-
|
|
56
|
-
// Sync base variables with theme colors (for web components)
|
|
57
|
-
// Colors
|
|
58
|
-
$base-accent-color: $accent-color;
|
|
59
|
-
$base-accent-color-hover: color.adjust($base-accent-color, $lightness: 10%);
|
|
60
|
-
$base-accent-color-active: color.adjust($base-accent-color, $lightness: 20%);
|
|
61
|
-
$base-accent-color-light: $accent-light;
|
|
62
|
-
$base-accent-color-light-hover: rgba($base-accent-color, 0.12);
|
|
63
|
-
$base-primary-bg: $dark-blue-slate-800;
|
|
64
|
-
$base-primary-bg-hover: $dark-blue-slate-700;
|
|
65
|
-
$base-text-color-1: $dark-blue-slate-100;
|
|
66
|
-
$base-text-color-2: $dark-blue-slate-400;
|
|
67
|
-
$base-text-color-3: #6b7280;
|
|
68
|
-
$base-text-color-4: #4b5563;
|
|
69
|
-
$base-text-on-accent: #ffffff;
|
|
70
|
-
$base-border-color: $dark-blue-slate-700;
|
|
71
|
-
|
|
72
|
-
// Input fields
|
|
73
|
-
$base-input-background: $dark-blue-slate-900;
|
|
74
|
-
$base-input-color: $dark-blue-slate-100;
|
|
75
|
-
$base-input-border: 1px solid $dark-blue-slate-700;
|
|
76
|
-
$base-input-border-hover: 1px solid $accent-color;
|
|
77
|
-
$base-input-border-focus: 1px solid $accent-color;
|
|
78
|
-
$base-input-placeholder-color: $dark-blue-slate-600;
|
|
79
|
-
$base-input-background-disabled: rgba($dark-blue-slate-800, 0.5);
|
|
80
|
-
|
|
81
|
-
// Dropdown/Popover
|
|
82
|
-
$base-dropdown-background: $dark-blue-slate-800;
|
|
83
|
-
$base-dropdown-border: 1px solid $dark-blue-slate-700;
|
|
84
|
-
$base-dropdown-box-shadow: 0 8px 16px rgba(0, 0, 0, 0.4);
|
|
85
|
-
|
|
86
|
-
// Tooltip
|
|
87
|
-
$base-tooltip-background: $dark-blue-slate-700;
|
|
88
|
-
$base-tooltip-text-color: #ffffff;
|
|
89
|
-
|
|
90
|
-
// Form focus colors - must match accent color
|
|
91
|
-
$input-focus-border-color: $accent-color;
|
|
92
|
-
$select-focus-border-color: $accent-color;
|
|
93
|
-
$textarea-focus-border-color: $accent-color;
|
|
94
|
-
|
|
95
|
-
// Checkbox colors - must match accent color
|
|
96
|
-
$checkbox-border-color-hover: $accent-color;
|
|
97
|
-
$checkbox-border-color-checked: $accent-color;
|
|
98
|
-
$checkbox-bg-checked: $accent-color;
|
|
99
|
-
$checkbox-bg-indeterminate: $accent-color;
|
|
100
|
-
$checkbox-focus-shadow: 0 0 0 2px rgba($accent-color, 0.25);
|
|
101
|
-
|
|
102
|
-
// Card colors
|
|
103
|
-
$card-bg: $dark-blue-slate-800;
|
|
104
|
-
$card-header-bg: $dark-blue-slate-900;
|
|
105
|
-
$card-footer-bg: $dark-blue-slate-900;
|
|
106
|
-
$card-tabs-bg: $dark-blue-slate-700;
|
|
107
|
-
|
|
108
|
-
// Input colors
|
|
109
|
-
$input-bg: $dark-blue-slate-900;
|
|
110
|
-
$input-border: $border-color;
|
|
111
|
-
$input-text: $text-primary;
|
|
112
|
-
|
|
113
|
-
// Table colors
|
|
114
|
-
$table-bg: $dark-blue-slate-800;
|
|
115
|
-
$table-header-bg: $dark-blue-slate-900;
|
|
116
|
-
$table-hover-bg: $dark-blue-slate-700;
|
|
117
|
-
$table-stripe: $dark-blue-slate-800;
|
|
118
|
-
|
|
119
|
-
// Button colors - blue-focused palette
|
|
120
|
-
$btn-primary-bg: $dark-blue-blue-700;
|
|
121
|
-
$btn-primary-bg-hover: $dark-blue-blue-800;
|
|
122
|
-
$btn-secondary-bg: $dark-blue-slate-700;
|
|
123
|
-
$btn-secondary-bg-hover: $dark-blue-slate-600;
|
|
124
|
-
$btn-success-bg: $dark-blue-cyan-600;
|
|
125
|
-
$btn-success-bg-hover: $dark-blue-cyan-700;
|
|
126
|
-
$btn-warning-bg: $dark-blue-sky-700;
|
|
127
|
-
$btn-warning-text: #ffffff;
|
|
128
|
-
$btn-danger-bg: $dark-blue-sky-800;
|
|
129
|
-
$btn-danger-bg-hover: $dark-blue-sky-900;
|
|
130
|
-
$btn-info-bg: $dark-blue-sky-600;
|
|
131
|
-
$btn-info-bg-hover: $dark-blue-sky-700;
|
|
132
|
-
$btn-light-bg: $dark-blue-slate-700;
|
|
133
|
-
$btn-light-text: $dark-blue-sky-50;
|
|
134
|
-
$btn-light-bg-hover: $dark-blue-slate-600;
|
|
135
|
-
$btn-dark-bg: $dark-blue-slate-900;
|
|
136
|
-
$btn-dark-bg-hover: $dark-blue-slate-950;
|
|
137
|
-
|
|
138
|
-
// Validation shadow colors - match button colors
|
|
139
|
-
$success-bg: $btn-success-bg;
|
|
140
|
-
$success-bg-light: rgba(34, 211, 238, 0.15);
|
|
141
|
-
$warning-bg: $btn-warning-bg;
|
|
142
|
-
$warning-bg-light: rgba(14, 165, 233, 0.15);
|
|
143
|
-
$danger-bg: $btn-danger-bg;
|
|
144
|
-
$danger-bg-light: rgba(7, 89, 133, 0.15);
|
|
145
|
-
|
|
146
|
-
// Modal colors
|
|
147
|
-
$modal-overlay-bg: rgba(0, 0, 0, 0.75);
|
|
148
|
-
$modal-content-bg: $dark-blue-slate-800;
|
|
149
|
-
|
|
150
|
-
// Profile name in header
|
|
151
|
-
$header-profile-name-color: #ffffff; // White text on dark header
|
|
152
|
-
|
|
153
|
-
@import '../core';
|
|
154
|
-
@import '../utilities';
|
|
155
|
-
@import '../base-css-variables';
|
|
156
|
-
|
|
157
|
-
// CSS Variables for page loader (FOUC prevention) and base theme variables
|
|
158
|
-
:root {
|
|
159
|
-
--page-loader-bg: rgba(26, 26, 26, 0.95);
|
|
160
|
-
--page-loader-spinner-border: #333;
|
|
161
|
-
--page-loader-spinner-accent: #3b82f6; // Blue
|
|
162
|
-
|
|
163
|
-
// Base CSS variables for web components (daterangepicker, multiselect, etc.)
|
|
164
|
-
@include output-base-css-variables;
|
|
165
|
-
}
|