Initialize project structure by creating necessary directories, default config file, and removing obsolete HTML components

This commit is contained in:
Christian Galo 2025-05-07 01:36:24 -05:00
parent 0c446e244b
commit b98ec87d8d
5 changed files with 253 additions and 128 deletions

View File

@ -36,15 +36,41 @@ var initCmd = &cobra.Command{
Run: func(cmd *cobra.Command, args []string) {
fmt.Println("init called")
// Create the directories and files needed for the member-console web application in the
// Create the directories and files needed for the member-console web application
targetDir := args[0]
componentsDir := filepath.Join(targetDir, "components")
if err := os.MkdirAll(componentsDir, 0755); err != nil {
fmt.Fprintf(os.Stderr, "Error creating components directory: %v\n", err)
// Create the target directory if it doesn't exist
if err := os.MkdirAll(targetDir, 0755); err != nil {
fmt.Fprintf(os.Stderr, "Error creating target directory: %v\n", err)
os.Exit(1)
}
// Create the templates, static, and assets directories
directories := []string{"templates", "static", "assets"}
for _, dir := range directories {
dirPath := filepath.Join(targetDir, dir)
if err := os.MkdirAll(dirPath, 0755); err != nil {
fmt.Fprintf(os.Stderr, "Error creating %s directory: %v\n", dir, err)
os.Exit(1)
}
}
// Create the config.yaml file
configFilePath := filepath.Join(targetDir, "mc-config.yaml")
configFile, err := os.Create(configFilePath)
if err != nil {
fmt.Fprintf(os.Stderr, "Error creating config file: %v\n", err)
os.Exit(1)
}
defer configFile.Close()
// Write default config to the config file
defaultConfig := "# Default configuration for member-console\n"
if _, err := configFile.WriteString(defaultConfig); err != nil {
fmt.Fprintf(os.Stderr, "Error writing to config file: %v\n", err)
os.Exit(1)
}
fmt.Printf("Created config file at %s\n", configFilePath)
fmt.Printf("Project initialized at %s\n", targetDir)
},
}

View File

@ -0,0 +1,223 @@
/*! modern-normalize v3.0.1 | MIT License | https://github.com/sindresorhus/modern-normalize */
/*
Document
========
*/
/**
Use a better box model (opinionated).
*/
*,
::before,
::after {
box-sizing: border-box;
}
/**
1. Improve consistency of default fonts in all browsers. (https://github.com/sindresorhus/modern-normalize/issues/3)
2. Correct the line height in all browsers.
3. Prevent adjustments of font size after orientation changes in iOS.
4. Use a more readable tab size (opinionated).
*/
html {
font-family:
system-ui,
'Segoe UI',
Roboto,
Helvetica,
Arial,
sans-serif,
'Apple Color Emoji',
'Segoe UI Emoji'; /* 1 */
line-height: 1.15; /* 2 */
-webkit-text-size-adjust: 100%; /* 3 */
tab-size: 4; /* 4 */
}
/*
Sections
========
*/
/**
Remove the margin in all browsers.
*/
body {
margin: 0;
}
/*
Text-level semantics
====================
*/
/**
Add the correct font weight in Chrome and Safari.
*/
b,
strong {
font-weight: bolder;
}
/**
1. Improve consistency of default fonts in all browsers. (https://github.com/sindresorhus/modern-normalize/issues/3)
2. Correct the odd 'em' font sizing in all browsers.
*/
code,
kbd,
samp,
pre {
font-family:
ui-monospace,
SFMono-Regular,
Consolas,
'Liberation Mono',
Menlo,
monospace; /* 1 */
font-size: 1em; /* 2 */
}
/**
Add the correct font size in all browsers.
*/
small {
font-size: 80%;
}
/**
Prevent 'sub' and 'sup' elements from affecting the line height in all browsers.
*/
sub,
sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: baseline;
}
sub {
bottom: -0.25em;
}
sup {
top: -0.5em;
}
/*
Tabular data
============
*/
/**
Correct table border color inheritance in Chrome and Safari. (https://issues.chromium.org/issues/40615503, https://bugs.webkit.org/show_bug.cgi?id=195016)
*/
table {
border-color: currentcolor;
}
/*
Forms
=====
*/
/**
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
*/
button,
input,
optgroup,
select,
textarea {
font-family: inherit; /* 1 */
font-size: 100%; /* 1 */
line-height: 1.15; /* 1 */
margin: 0; /* 2 */
}
/**
Correct the inability to style clickable types in iOS and Safari.
*/
button,
[type='button'],
[type='reset'],
[type='submit'] {
-webkit-appearance: button;
}
/**
Remove the padding so developers are not caught out when they zero out 'fieldset' elements in all browsers.
*/
legend {
padding: 0;
}
/**
Add the correct vertical alignment in Chrome and Firefox.
*/
progress {
vertical-align: baseline;
}
/**
Correct the cursor style of increment and decrement buttons in Safari.
*/
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
height: auto;
}
/**
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/
[type='search'] {
-webkit-appearance: textfield; /* 1 */
outline-offset: -2px; /* 2 */
}
/**
Remove the inner padding in Chrome and Safari on macOS.
*/
::-webkit-search-decoration {
-webkit-appearance: none;
}
/**
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to 'inherit' in Safari.
*/
::-webkit-file-upload-button {
-webkit-appearance: button; /* 1 */
font: inherit; /* 2 */
}
/*
Interactive
===========
*/
/*
Add the correct display in Chrome and Safari.
*/
summary {
display: list-item;
}

View File

@ -1,76 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Dashboard</title>
<style>
body {
font-family: Arial, sans-serif;
margin: 0;
padding: 0;
background-color: #f9f9f9;
color: #333;
}
header {
background-color: #f0f2f5;
padding: 1rem;
display: flex;
justify-content: space-between;
align-items: center;
box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}
.user-info {
display: flex;
align-items: center;
gap: 12px;
}
.user-info span {
font-weight: 600;
}
.btn {
padding: 8px 16px;
border: none;
border-radius: 4px;
cursor: pointer;
text-decoration: none;
font-weight: 500;
transition: background-color 0.2s ease;
}
.btn-account {
background-color: #4285f4;
color: white;
}
.btn-account:hover {
background-color: #3367d6;
}
.btn-logout {
background-color: #f44336;
color: white;
}
.btn-logout:hover {
background-color: #d32f2f;
}
.content {
padding: 2rem;
max-width: 1200px;
margin: 0 auto;
}
</style>
<script src="https://unpkg.com/htmx.org"></script>
</head>
<body>
<header>
<div class="user-info">
<span>Welcome, User!</span>
<a href="http://localhost:8080/realms/master/account" class="btn btn-account">Account</a>
<a href="/logout" class="btn btn-logout">Logout</a>
</div>
</header>
<div class="content">
<!-- Rest of your protected content -->
<h1>Dashboard</h1>
<p>This is your protected dashboard content.</p>
</div>
</body>
</html>

View File

@ -1,48 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Logout</title>
<style>
body {
font-family: Arial, sans-serif;
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
margin: 0;
background-color: #f0f2f5;
}
.logout-container {
background: white;
padding: 2rem;
border-radius: 8px;
box-shadow: 0 2px 4px rgba(0,0,0,0.1);
text-align: center;
}
.logout-button {
background-color: #f44336;
color: white;
padding: 14px 20px;
margin: 8px 0;
border: none;
border-radius: 4px;
cursor: pointer;
font-size: 16px;
}
.logout-button:hover {
background-color: #d32f2f;
}
</style>
</head>
<body>
<div class="logout-container">
<h1>Logout</h1>
<p>Are you sure you want to log out?</p>
<button class="logout-button" onclick="window.location.href='/logout'">
Logout
</button>
</div>
</body>
</html>