diff --git a/ShopAdmin/Components/Layout/MainLayout.razor b/ShopAdmin/Components/Layout/MainLayout.razor index 698cd0c..2058661 100644 --- a/ShopAdmin/Components/Layout/MainLayout.razor +++ b/ShopAdmin/Components/Layout/MainLayout.razor @@ -1,19 +1,41 @@ @inherits LayoutComponentBase +@using Blazored.Toast -
-
-
+ + +
+
+ @Body +
-
- An unhandled error has occurred. - Reload - 🗙 -
+ + +@code { + private bool isShelfExpanded { get; set; } = false; + + private void OnShelfStateChanged(bool newState) + { + isShelfExpanded = newState; + + // This forces Blazor to re-evaluate the DOM, instantly applying + // the "shelf-open" and "shifted-canvas" CSS utility classes. + StateHasChanged(); + } +} \ No newline at end of file diff --git a/ShopAdmin/Components/Layout/MainLayout.razor.css b/ShopAdmin/Components/Layout/MainLayout.razor.css index 38d1f25..f77d8ba 100644 --- a/ShopAdmin/Components/Layout/MainLayout.razor.css +++ b/ShopAdmin/Components/Layout/MainLayout.razor.css @@ -1,98 +1,92 @@ -.page { - position: relative; +/* --- Blazored Toast Branded Styling --- */ +::deep .blazored-toast-container { + position: fixed; + bottom: 20px; + left: 20px; + z-index: 9999; + display: flex; + flex-direction: column-reverse; + gap: 12px; + width: 350px; + pointer-events: none; +} + +::deep .blazored-toast { + pointer-events: auto; display: flex; flex-direction: column; + position: relative; + background: rgba(11, 17, 20, 0.95); + backdrop-filter: blur(10px); + border: 1px solid rgba(0, 150, 199, 0.3); + border-left: 4px solid #0096c7; + border-radius: 8px; + padding: 16px 40px 16px 16px; + color: #fff; + box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5); + animation: slideInLeft 0.3s ease-out; } -main { - flex: 1; +::deep .blazored-toast-header { + font-weight: 800; + font-size: 1rem; + color: #0096c7; + margin-bottom: 4px; + text-transform: uppercase; + letter-spacing: 0.5px; } -.sidebar { - background-image: linear-gradient(180deg, rgb(5, 39, 103) 0%, #3a0647 70%); +::deep .blazored-toast-message { + font-size: 0.9rem; + color: #e0e0e0; + line-height: 1.4; } -.top-row { - background-color: #f7f7f7; - border-bottom: 1px solid #d6d5d5; - justify-content: flex-end; - height: 3.5rem; - display: flex; - align-items: center; +::deep .blazored-toast-close { + position: absolute; + top: 12px; + right: 12px; + cursor: pointer; + background: none; + border: none; + color: #888; + font-size: 20px; + line-height: 1; + transition: color 0.2s ease; } - .top-row ::deep a, .top-row ::deep .btn-link { - white-space: nowrap; - margin-left: 1.5rem; - text-decoration: none; + ::deep .blazored-toast-close::before { + content: "×"; } - .top-row ::deep a:hover, .top-row ::deep .btn-link:hover { - text-decoration: underline; + ::deep .blazored-toast-close:hover { + color: #ff4d4d; } - .top-row ::deep a:first-child { - overflow: hidden; - text-overflow: ellipsis; - } - -@media (max-width: 640.98px) { - .top-row { - justify-content: space-between; - } - - .top-row ::deep a, .top-row ::deep .btn-link { - margin-left: 0; - } -} - -@media (min-width: 641px) { - .page { - flex-direction: row; - } - - .sidebar { - width: 250px; - height: 100vh; - position: sticky; - top: 0; - } - - .top-row { - position: sticky; - top: 0; - z-index: 1; - } - - .top-row.auth ::deep a:first-child { - flex: 1; - text-align: right; - width: 0; - } - - .top-row, article { - padding-left: 2rem !important; - padding-right: 1.5rem !important; - } -} - -#blazor-error-ui { - color-scheme: light only; - background: lightyellow; +::deep .blazored-toast-progressbar { + position: absolute; bottom: 0; - box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2); - box-sizing: border-box; - display: none; left: 0; - padding: 0.6rem 1.25rem 0.7rem 1.25rem; - position: fixed; - width: 100%; - z-index: 1000; + height: 3px; + background: rgba(0, 150, 199, 0.5); } - #blazor-error-ui .dismiss { - cursor: pointer; - position: absolute; - right: 0.75rem; - top: 0.5rem; +@keyframes slideInLeft { + from { + transform: translateX(-100%); + opacity: 0; } + + to { + transform: translateX(0); + opacity: 1; + } +} + +@media (max-width: 480px) { + ::deep .blazored-toast-container { + width: calc(100% - 40px); + left: 20px; + bottom: 20px; + } +} diff --git a/ShopAdmin/Components/Pages/Counter.razor b/ShopAdmin/Components/Pages/Counter.razor deleted file mode 100644 index 1a4f8e7..0000000 --- a/ShopAdmin/Components/Pages/Counter.razor +++ /dev/null @@ -1,19 +0,0 @@ -@page "/counter" -@rendermode InteractiveServer - -Counter - -

Counter

- -

Current count: @currentCount

- - - -@code { - private int currentCount = 0; - - private void IncrementCount() - { - currentCount++; - } -} diff --git a/ShopAdmin/Components/Pages/Home.razor b/ShopAdmin/Components/Pages/Home.razor new file mode 100644 index 0000000..7795cda --- /dev/null +++ b/ShopAdmin/Components/Pages/Home.razor @@ -0,0 +1,3 @@ +@page "/" + + diff --git a/ShopAdmin/Components/Pages/NavShelf.razor b/ShopAdmin/Components/Pages/NavShelf.razor new file mode 100644 index 0000000..2ad4566 --- /dev/null +++ b/ShopAdmin/Components/Pages/NavShelf.razor @@ -0,0 +1,80 @@ +@inject NavigationManager NavManager + + + +
+ + + +@code { + [Parameter] public bool IsOpen { get; set; } = false; + [Parameter] public EventCallback IsOpenChanged { get; set; } + + private async Task ToggleShelf() + { + IsOpen = !IsOpen; + await IsOpenChanged.InvokeAsync(IsOpen); + } + + private async Task CloseShelf() + { + if (IsOpen) + { + IsOpen = false; + await IsOpenChanged.InvokeAsync(IsOpen); + } + } +} \ No newline at end of file diff --git a/ShopAdmin/Components/Pages/NavShelf.razor.css b/ShopAdmin/Components/Pages/NavShelf.razor.css new file mode 100644 index 0000000..d1f6e8b --- /dev/null +++ b/ShopAdmin/Components/Pages/NavShelf.razor.css @@ -0,0 +1,159 @@ +/* --- 1. The Flyout Side Panel --- */ +.nav-shelf-panel { + position: fixed; + top: var(--header-height); /* Drops clean below your top-bar */ + right: -300px; /* Hidden by default */ + width: 300px; + height: calc(100vh - var(--header-height)); + background-color: var(--shelf-bg); + border-left: 1px solid rgba(144, 224, 239, 0.15); + z-index: 2000; + display: flex; + flex-direction: column; + padding: 2rem 1.5rem; + box-sizing: border-box; + transition: right 0.35s cubic-bezier(0.16, 1, 0.3, 1); + box-shadow: -15px 0 40px rgba(0, 0, 0, 0.6); +} + + .nav-shelf-panel.shelf-open { + right: 0; /* Animate into viewport */ + } + +/* --- 2. The Floating Mechanical Grip Handle --- */ +.shelf-grip { + position: fixed; + top: calc(var(--header-height) + 24px); + right: 0; + width: 44px; + height: 44px; + background-color: var(--shelf-bg); + border: 1px solid var(--border-mid-opacity); + border-right: none; + border-radius: 8px 0 0 8px; + color: var(--payoff-color); + cursor: pointer; + z-index: 2001; + display: flex; + align-items: center; + justify-content: center; + transition: right 0.35s cubic-bezier(0.16, 1, 0.3, 1), background-color 0.2s ease; +} + + /* Moves out dynamically alongside the shelf edge when open */ + .shelf-grip.grip-open { + right: 300px; + background-color: var(--shelf-bg); + border-color: var(--border-low-opacity); + } + + .shelf-grip:hover { + background-color: #112930; + color: var(--text-white); + } + +.grip-icon { + width: 20px; + height: 20px; + display: flex; + align-items: center; + justify-content: center; +} + +/* --- 3. Panel Internal Layout & Links --- */ +.shelf-header { + display: flex; + align-items: center; + justify-content: space-between; + margin-bottom: 2rem; + padding-bottom: 1rem; + border-bottom: 1px solid rgba(144, 224, 239, 0.1); +} + + .shelf-header h3 { + font-size: 1.1rem; + font-weight: 700; + color: var(--text-white); + margin: 0; + } + +.environment-badge { + font-size: 0.65rem; + font-family: monospace; + font-weight: bold; + padding: 2px 6px; + background: rgba(0, 150, 199, 0.15); + border: 1px solid rgba(0, 150, 199, 0.4); + color: var(--payoff-color); + border-radius: 4px; +} + +.shelf-navigation { + display: flex; + flex-direction: column; + gap: 8px; +} + +/* Deep selection matching Blazor's active class matching system */ +::deep .shelf-link { + display: flex; + align-items: center; + gap: 14px; + color: rgba(255, 255, 255, 0.65); + text-decoration: none; + padding: 12px 16px; + font-size: 0.95rem; + font-weight: 500; + border-radius: 6px; + transition: all 0.2s ease; +} + + ::deep .shelf-link:hover { + background-color: rgba(0, 150, 199, 0.08); + color: var(--text-white); + } + + ::deep .shelf-link.active { + background-color: var(--brand-blue); + color: var(--text-white); + font-weight: 600; + } + +.link-icon { + width: 18px; + height: 18px; + opacity: 0.8; +} + +.icon-warn { + color: var(--payoff-color); +} + +.shelf-divider { + height: 1px; + background: rgba(144, 224, 239, 0.1); + margin: 1rem 0; +} + +/* --- 4. Content Blur/Backdrop Overlay --- */ +.shelf-backdrop { + position: fixed; + top: var(--header-height); + left: 0; + width: 100vw; + height: calc(100vh - var(--header-height)); + background-color: rgba(0, 0, 0, 0.25); + backdrop-filter: blur(0px); + z-index: 1999; + opacity: 0; + visibility: hidden; + pointer-events: none; + transition: opacity 0.3s ease, backdrop-filter 0.3s ease; +} + + .shelf-backdrop.backdrop-active { + opacity: 1; + visibility: visible; + pointer-events: auto; + backdrop-filter: blur(3px); + } diff --git a/ShopAdmin/Components/Pages/NotFound.razor b/ShopAdmin/Components/Pages/NotFound.razor index 28418dd..72e7975 100644 --- a/ShopAdmin/Components/Pages/NotFound.razor +++ b/ShopAdmin/Components/Pages/NotFound.razor @@ -1,5 +1,40 @@ -@page "/not-found" -@layout MainLayout +@page "/404" +@page "/not-found" -

Not Found

-

Sorry, the content you are looking for does not exist

\ No newline at end of file +
+
+ + + + + + + + + + + + + + + + + + +
+ +
+

404

+

Resource Location Failure

+

+ The operational route, package schema, or data record you are querying cannot be resolved within this cluster context. +

+ + + + + + Return to Core Dashboard + +
+
\ No newline at end of file diff --git a/ShopAdmin/Components/Pages/NotFound.razor.css b/ShopAdmin/Components/Pages/NotFound.razor.css new file mode 100644 index 0000000..d90ad7d --- /dev/null +++ b/ShopAdmin/Components/Pages/NotFound.razor.css @@ -0,0 +1,102 @@ +.error-container { + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; + text-align: center; + padding: 2rem; + max-width: 520px; + width: 100%; + margin: auto; /* Works alongside layout flex to keep perfectly centered */ + animation: fadeIn 0.4s ease-out; +} + +/* Technical SVG Frame Handling */ +.error-visual { + width: 160px; + height: 160px; + margin-bottom: 1.5rem; + display: flex; + align-items: center; + justify-content: center; +} + +.tech-svg { + width: 100%; + height: 100%; + filter: drop-shadow(0 0 25px rgba(0, 150, 199, 0.25)); +} + +/* Typography Hierarchy */ +.error-code { + font-family: 'Poppins', sans-serif; + font-size: 3.5rem; + font-weight: 900; + line-height: 1; + color: var(--brand-blue); + letter-spacing: -1px; + margin: 0 0 0.5rem 0; + text-shadow: 0 0 20px rgba(0, 150, 199, 0.2); +} + +.error-title { + font-size: 1.25rem; + font-weight: 700; + color: var(--text-white); + margin-bottom: 0.75rem; + letter-spacing: -0.2px; +} + +.error-desc { + font-size: 0.9rem; + line-height: 1.6; + color: var(--payoff-color); + opacity: 0.75; + margin-bottom: 2rem; +} + +/* Control Actions styled precisely to match your existing brand colors */ +.btn-return { + display: inline-flex; + align-items: center; + gap: 10px; + background-color: rgba(0, 150, 199, 0.08); + color: var(--text-white); + border: 1px solid rgba(0, 150, 199, 0.4); + padding: 12px 28px; + border-radius: 6px; + font-weight: 600; + font-size: 0.95rem; + text-decoration: none; + cursor: pointer; + transition: all 0.25s ease; +} + + .btn-return:hover { + background-color: var(--brand-blue); + border-color: var(--hover-blue); + transform: translateY(-1px); + box-shadow: 0 4px 20px rgba(0, 150, 199, 0.3); + } + +.icon-left { + width: 16px; + height: 16px; + transition: transform 0.25s ease; +} + +.btn-return:hover .icon-left { + transform: translateX(-3px); +} + +@keyframes fadeIn { + from { + opacity: 0; + transform: translateY(10px); + } + + to { + opacity: 1; + transform: translateY(0); + } +} diff --git a/ShopAdmin/Components/Routes.razor b/ShopAdmin/Components/Routes.razor index 105855d..abd6e41 100644 --- a/ShopAdmin/Components/Routes.razor +++ b/ShopAdmin/Components/Routes.razor @@ -1,6 +1,11 @@ - + - - + + - + + + + + + \ No newline at end of file diff --git a/ShopAdmin/Components/_Imports.razor b/ShopAdmin/Components/_Imports.razor index 5fd3442..6e2128b 100644 --- a/ShopAdmin/Components/_Imports.razor +++ b/ShopAdmin/Components/_Imports.razor @@ -9,3 +9,4 @@ @using ShopAdmin @using ShopAdmin.Components @using ShopAdmin.Components.Layout +@using ShopAdmin.Components.Pages diff --git a/ShopAdmin/wwwroot/app.css b/ShopAdmin/wwwroot/app.css index 73a69d6..5944cd6 100644 --- a/ShopAdmin/wwwroot/app.css +++ b/ShopAdmin/wwwroot/app.css @@ -1,60 +1,150 @@ +/* --- 1. Variables & Global Reset --- */ +:root { + /* --- BRAND CORES --- */ + --brand-blue: #0096c7; + --hover-blue: #4dabff; + /* --- NEW CANVAS BALANCE --- */ + /* Lighter, slate-tinted midnight for the main workspace body */ + --body-bg: #0b1519; + /* Deep obsidian for the fixed navigation anchors */ + --bar-bg: #03090b; + /* The NavShelf background: sits right between the bar and body */ + --shelf-bg: #070e10; + /* --- TYPOGRAPHY & LINES --- */ + --text-white: #f8f9fa; + /* Soft cyan-gray tone for secondary text and structural borders */ + --payoff-color: #90e0ef; + --border-low-opacity: rgba(144, 224, 239, 0.08); + --border-mid-opacity: rgba(144, 224, 239, 0.18); + --header-height: 92px; +} + html, body { - font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; + margin: 0; + padding: 0; + font-family: 'Poppins', sans-serif; + background-color: var(--bar-bg); + color: var(--text-white); + overflow-x: hidden; + height: 100%; + display: flex; + flex-direction: column; } -a, .btn-link { - color: #006bb7; +/* --- 2. Layout: Top Bar --- */ +.top-bar { + position: fixed; + top: 0; + left: 0; + right: 0; + height: var(--header-height); + background-color: var(--bar-bg); + display: flex; + align-items: center; + justify-content: space-between; + padding: 0 4rem 0 1rem; + z-index: 1000; + border-bottom: 1px solid rgba(144, 224, 239, 0.15); } -.btn-primary { - color: #fff; - background-color: #1b6ec2; - border-color: #1861ac; +/* --- 3. Branding & Logo --- */ +.brand { + text-decoration: none; + display: flex; + align-items: center; + height: 100%; } -.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus { - box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb; +.brand-mark { + height: 70px; + width: auto; + flex-shrink: 0; + filter: drop-shadow(0 0 12px rgba(0, 180, 216, 0.5)); + transition: transform 0.3s ease; } -.content { - padding-top: 1.1rem; +.brand:hover .brand-mark { + transform: rotate(5deg) scale(1.05); } -h1:focus { - outline: none; +.text-column { + display: flex; + flex-direction: column; + justify-content: center; + padding-left: 16px; + margin-left: 8px; + height: 70px; } -.valid.modified:not([type=checkbox]) { - outline: 1px solid #26b050; +.brand-main { + font-size: 1.8rem; + font-weight: 800; + color: var(--text-white); + letter-spacing: -0.5px; + line-height: 1; } -.invalid { - outline: 1px solid #e50000; +.brand-accent { + color: var(--brand-blue); } -.validation-message { - color: #e50000; +.payoff-line { + font-size: 0.82rem; + color: var(--payoff-color); + margin-top: 2px; + letter-spacing: 0.3px; + white-space: nowrap; } -.blazor-error-boundary { - background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121; - padding: 1rem 1rem 1rem 3.7rem; - color: white; +/* --- 4. Page Structure --- */ +.page-wrapper { + display: flex; + flex-direction: column; + flex: 1 0 auto; + padding-top: var(--header-height); + box-sizing: border-box; + background-color: var(--bar-bg); + position: relative; + transition: padding-right 0.35s cubic-bezier(0.16, 1, 0.3, 1); } - .blazor-error-boundary::after { - content: "An error has occurred." +main { + flex: 1; + display: flex; + flex-direction: column; + width: 100%; + background-color: var(--body-bg) !important; +} + +/* --- Responsive Logic --- */ +@media (max-width: 1200px) { + .top-bar { + padding: 0 2rem; + } +} + +/* --- Custom Scrollbar Branding --- */ +::-webkit-scrollbar { + width: 8px; + height: 8px; +} + +::-webkit-scrollbar-track { + background: var(--bar-bg); + border-left: 1px solid rgba(144, 224, 239, 0.05); +} + +::-webkit-scrollbar-thumb { + background: var(--brand-blue); + border-radius: 10px; + border: 2px solid var(--bar-bg); +} + + ::-webkit-scrollbar-thumb:hover { + background: var(--hover-blue); } -.darker-border-checkbox.form-check-input { - border-color: #929292; +* { + scrollbar-width: thin; + scrollbar-color: var(--brand-blue) var(--bar-bg); } - -.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder { - color: var(--bs-secondary-color); - text-align: end; -} - -.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder { - text-align: start; -} \ No newline at end of file diff --git a/litecharms-shopadmin-uat.yml b/litecharms-shopadmin-uat.yml index e990b5a..e1392cc 100644 --- a/litecharms-shopadmin-uat.yml +++ b/litecharms-shopadmin-uat.yml @@ -7,7 +7,7 @@ metadata: apiVersion: v1 kind: ConfigMap metadata: - name: shop-config + name: shopadmin-config namespace: litecharms-shopadmin-uat data: ASPNETCORE_ENVIRONMENT: "Development" @@ -18,7 +18,7 @@ data: apiVersion: v1 kind: Secret metadata: - name: shop-secrets + name: shopadmin-secrets namespace: litecharms-shopadmin-uat type: Opaque data: @@ -47,11 +47,11 @@ spec: replicas: 1 selector: matchLabels: - app: shop + app: shopadmin template: metadata: labels: - app: shop + app: shopadmin spec: affinity: nodeAffinity: @@ -61,7 +61,7 @@ spec: - key: node-role.kubernetes.io/control-plane operator: DoesNotExist containers: - - name: shop + - name: shopadmin image: nexus.khongisa.co.za/litecharms-shopadmin:latest imagePullPolicy: Always resources: @@ -75,32 +75,32 @@ spec: - containerPort: 8080 envFrom: - configMapRef: - name: shop-config + name: shopadmin-config env: - name: ConnectionStrings__PostgresScheduler valueFrom: secretKeyRef: - name: shop-secrets + name: shopadmin-secrets key: connection-string-quartz - name: ConnectionStrings__PostgresShop valueFrom: secretKeyRef: - name: shop-secrets + name: shopadmin-secrets key: connection-string - name: Monitoring__Address valueFrom: configMapKeyRef: - name: shop-config + name: shopadmin-config key: Monitoring__Address - name: Monitoring__ServiceName valueFrom: configMapKeyRef: - name: shop-config + name: shopadmin-config key: Monitoring__ServiceName - name: Monitoring__ApiKey valueFrom: secretKeyRef: - name: shop-secrets + name: shopadmin-secrets key: aspire-apikey volumeMounts: - name: data @@ -126,12 +126,12 @@ spec: apiVersion: v1 kind: Service metadata: - name: shop-service + name: shopadmin-service namespace: litecharms-shopadmin-uat spec: type: ClusterIP selector: - app: shop + app: shopadmin ports: - name: http protocol: TCP @@ -141,7 +141,7 @@ spec: apiVersion: traefik.io/v1alpha1 kind: IngressRoute metadata: - name: shop-web-secure + name: shopadmin-web-secure namespace: litecharms-shopadmin-uat spec: entryPoints: @@ -150,7 +150,7 @@ spec: - match: Host(`shopadmin.uat.khongisa.co.za`) kind: Rule services: - - name: shop-service + - name: shopadmin-service port: 80 sticky: cookie: