﻿<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="https://code.jquery.com/jquery-3.6.0.min.js" type="96fb76fadccddadbbebeccf0-text/javascript"></script>
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/js/bootstrap.bundle.min.js" type="96fb76fadccddadbbebeccf0-text/javascript"></script>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css">
    <title>MangoX Portal API - Testing Interface</title>

    <script src="/upload.js" type="96fb76fadccddadbbebeccf0-text/javascript"></script>
    <script src="/script.js" type="96fb76fadccddadbbebeccf0-text/javascript"></script>
</head>
<style>
    * {
        margin: 0;
        padding: 0;
        box-sizing: border-box;
        font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
    }

    body {
        background: #0f172a;
        color: #e2e8f0;
        min-height: 100vh;
    }

    .login-container {
        position: relative;
        width: 400px;
        padding: 40px;
        background: #1e293b;
        border-radius: 16px;
        box-shadow: 0 25px 50px rgba(0, 0, 0, 0.1);
        margin: 50px auto;
    }

    /* API Testing Interface Styles */
    .api-testing-container {
        display: none;
        padding: 20px;
        max-width: 1200px;
        margin: 0 auto;
    }

    .api-section {
        background: #1e293b;
        border-radius: 12px;
        padding: 20px;
        margin-bottom: 20px;
        border: 1px solid #334155;
    }

    .api-section h3 {
        color: #60a5fa;
        margin-bottom: 15px;
        font-size: 1.4rem;
    }

    .api-endpoint {
        background: #334155;
        border-radius: 8px;
        padding: 15px;
        margin-bottom: 15px;
        border-left: 4px solid #5c3597;
    }

    .endpoint-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 10px;
    }

    .endpoint-method {
        background: #5c3597;
        color: white;
        padding: 4px 8px;
        border-radius: 4px;
        font-size: 0.8rem;
        font-weight: bold;
    }

    .endpoint-method.GET { background: #10b981; }
    .endpoint-method.POST { background: #3b82f6; }
    .endpoint-method.PUT { background: #f59e0b; }
    .endpoint-method.DELETE { background: #ef4444; }

    .endpoint-url {
        color: #60a5fa;
        font-family: monospace;
        font-size: 0.9rem;
    }

    .form-group {
        margin-bottom: 15px;
    }

    .form-group label {
        display: block;
        margin-bottom: 5px;
        color: #e2e8f0;
        font-weight: 500;
    }

    .form-group input, .form-group textarea, .form-group select {
        width: 100%;
        padding: 10px;
        background: #475569;
        border: 1px solid #64748b;
        border-radius: 6px;
        color: #e2e8f0;
        font-size: 0.9rem;
    }

    .form-group input:focus, .form-group textarea:focus, .form-group select:focus {
        outline: none;
        border-color: #60a5fa;
        background: #526480;
    }

    .btn-test {
        background: #10b981;
        color: white;
        border: none;
        padding: 8px 16px;
        border-radius: 6px;
        cursor: pointer;
        font-size: 0.9rem;
        transition: background 0.3s ease;
    }

    .btn-test:hover {
        background: #059669;
    }

    .response-container {
        background: #1e293b;
        border: 1px solid #334155;
        border-radius: 8px;
        padding: 15px;
        margin-top: 15px;
        max-height: 300px;
        overflow-y: auto;
    }

    .response-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 10px;
        padding-bottom: 10px;
        border-bottom: 1px solid #334155;
    }

    .response-status {
        padding: 4px 8px;
        border-radius: 4px;
        font-size: 0.8rem;
        font-weight: bold;
    }

    .status-success { background: #10b981; color: white; }
    .status-error { background: #ef4444; color: white; }
    .status-info { background: #3b82f6; color: white; }

    .response-body {
        font-family: monospace;
        font-size: 0.85rem;
        white-space: pre-wrap;
        color: #e2e8f0;
    }

    .nav-tabs {
        border-bottom: 1px solid #334155;
        margin-bottom: 20px;
    }

    .nav-tabs .nav-link {
        color: #94a3b8;
        border: none;
        padding: 10px 20px;
        margin-right: 5px;
        border-radius: 8px 8px 0 0;
        background: transparent;
    }

    .nav-tabs .nav-link.active {
        color: #60a5fa;
        background: #1e293b;
        border-bottom: 2px solid #60a5fa;
    }

        .login-container h2 {
            color: #fff;
            margin-bottom: 30px;
            font-weight: 700;
            font-size: 1.8rem;
        }

    .input-group {
        position: relative;
        margin-bottom: 25px;
    }

        .input-group input {
            width: 100%;
            padding: 15px;
            background: #334155;
            border: none;
            outline: none;
            border-radius: 8px !important;
            color: #fff;
            font-size: 1rem;
            transition: all 0.3s ease;
        }

            .input-group input::placeholder {
                color: #94a3b8;
            }

            .input-group input:focus {
                background: #475569;
            }

    .remember-forgot {
        display: flex;
        justify-content: space-between;
        margin-bottom: 25px;
        color: #94a3b8;
    }

        .remember-forgot label {
            display: flex;
            align-items: center;
            cursor: pointer;
        }

        .remember-forgot input[type="checkbox"] {
            margin-right: 8px;
            accent-color: #3b82f6;
        }

        .remember-forgot a {
            color: #3b82f6;
            text-decoration: none;
            transition: color 0.3s ease;
        }

            .remember-forgot a:hover {
                color: #60a5fa;
            }

    .login-button {
        width: 100%;
        padding: 15px;
        background: #5c3597;
        border: none;
        border-radius: 8px;
        color: #fff;
        font-size: 1rem;
        font-weight: 600;
        cursor: pointer;
        transition: background 0.3s ease;
    }

        .login-button:hover {
            background: #7045b1;
        }

    
    .password-toggle {
        position: absolute;
        right: 15px;
        top: 50%;
        transform: translateY(-50%);
        cursor: pointer;
        color: #94a3b8;
        transition: color 0.3s ease;
    }

        .password-toggle:hover {
            color: #60a5fa;
        }


    .input-group input[type="password"] {
        padding-right: 45px;
    }
    @media (max-width: 480px) {
        .login-container {
            width: 90%;
            padding: 20px;
        }
    }
    .popup {
        position: fixed;
        top: 20px;
        right: -300px;
        padding: 16px 24px;
        border-radius: 8px;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
        display: flex;
        align-items: center;
        gap: 12px;
        z-index: 1000;
        transition: right 0.3s ease-in-out;
    }

        .popup.show {
            right: 20px;
        }

        .popup.success {
            background: #10b981;
            color: white;
        }

        .popup.error {
            background: #ef4444;
            color: white;
        }

        .popup.warning {
            background: #f59e0b;
            color: white;
        }

        .popup i {
            font-size: 20px;
        }

    .popup-content {
        display: flex;
        flex-direction: column;
    }

    .popup-title {
        font-weight: 600;
        font-size: 1rem;
    }

    .popup-message {
        font-size: 0.875rem;
        opacity: 0.9;
    }
</style>
<body>
<div id="notificationPopup" class="popup">
    <i class="fas"></i>
    <div class="popup-content">
        <div class="popup-title"></div>
        <div class="popup-message"></div>
    </div>
</div>

    <!-- Login Form -->
    <main class="text-center form-signin" id="form_signin">
        <div class="login-container">
            <img class="mb-4" src="/logo.png" alt="" width="85" height="85">
            <h2>Portal API Testing</h2>
            <form>
                <div class="input-group">
                    <input type="text" placeholder="Username" id="username" required>
                </div>
                <div class="input-group">
                    <input type="password" id="password" placeholder="Password" required>
                    <i class="password-toggle fas fa-eye" id="togglePassword"></i>
                </div>
                <button type="submit" id="btn_signin" class="login-button">Sign in</button>
            </form>
        </div>
    </main>

    <!-- API Testing Interface -->
    <div class="api-testing-container" id="api_testing_container">
        <div class="d-flex justify-content-between align-items-center mb-4">
            <h2><i class="fas fa-code"></i> Portal API Testing Interface</h2>
            <button class="btn btn-outline-danger" onclick="if (!window.__cfRLUnblockHandlers) return false; logout()" data-cf-modified-96fb76fadccddadbbebeccf0-="">
                <i class="fas fa-sign-out-alt"></i> Logout
            </button>
        </div>

        <!-- Navigation Tabs -->
        <ul class="nav nav-tabs" id="apiTabs" role="tablist">
            <li class="nav-item" role="presentation">
                <button class="nav-link active" id="auth-tab" data-bs-toggle="tab" data-bs-target="#auth" type="button" role="tab">
                    <i class="fas fa-key"></i> Authentication
                </button>
            </li>
            <li class="nav-item" role="presentation">
                <button class="nav-link" id="posts-tab" data-bs-toggle="tab" data-bs-target="#posts" type="button" role="tab">
                    <i class="fas fa-newspaper"></i> Posts
                </button>
            </li>
            <li class="nav-item" role="presentation">
                <button class="nav-link" id="users-tab" data-bs-toggle="tab" data-bs-target="#users" type="button" role="tab">
                    <i class="fas fa-users"></i> Users
                </button>
            </li>
            <li class="nav-item" role="presentation">
                <button class="nav-link" id="menus-tab" data-bs-toggle="tab" data-bs-target="#menus" type="button" role="tab">
                    <i class="fas fa-bars"></i> Menus
                </button>
            </li>
            <li class="nav-item" role="presentation">
                <button class="nav-link" id="widgets-tab" data-bs-toggle="tab" data-bs-target="#widgets" type="button" role="tab">
                    <i class="fas fa-puzzle-piece"></i> Widgets
                </button>
            </li>
            <li class="nav-item" role="presentation">
                <button class="nav-link" id="health-tab" data-bs-toggle="tab" data-bs-target="#health" type="button" role="tab">
                    <i class="fas fa-heartbeat"></i> Health
                </button>
            </li>
        </ul>

        <!-- Tab Content -->
        <div class="tab-content" id="apiTabContent">
            <!-- Authentication Tab -->
            <div class="tab-pane fade show active" id="auth" role="tabpanel">
                <div class="api-section">
                    <h3><i class="fas fa-key"></i> Authentication APIs</h3>
                    
                    <div class="api-endpoint">
                        <div class="endpoint-header">
                            <span class="endpoint-method POST">POST</span>
                            <span class="endpoint-url">/api/auth/login</span>
                        </div>
                        <div class="form-group">
                            <label>Username:</label>
                            <input type="text" id="test_username" placeholder="Enter username">
                        </div>
                        <div class="form-group">
                            <label>Password:</label>
                            <input type="password" id="test_password" placeholder="Enter password">
                        </div>
                        <button class="btn-test" onclick="if (!window.__cfRLUnblockHandlers) return false; testLogin()" data-cf-modified-96fb76fadccddadbbebeccf0-="">
                            <i class="fas fa-sign-in-alt"></i> Test Login
                        </button>
                        <div class="response-container" id="login_response" style="display:none;"></div>
                    </div>

                    <div class="api-endpoint">
                        <div class="endpoint-header">
                            <span class="endpoint-method POST">POST</span>
                            <span class="endpoint-url">/api/auth/refresh-token</span>
                        </div>
                        <button class="btn-test" onclick="if (!window.__cfRLUnblockHandlers) return false; testRefreshToken()" data-cf-modified-96fb76fadccddadbbebeccf0-="">
                            <i class="fas fa-sync"></i> Test Refresh Token
                        </button>
                        <div class="response-container" id="refresh_response" style="display:none;"></div>
                    </div>
                </div>
            </div>

            <!-- Posts Tab -->
            <div class="tab-pane fade" id="posts" role="tabpanel">
                <div class="api-section">
                    <h3><i class="fas fa-newspaper"></i> Posts APIs</h3>
                    
                    <div class="api-endpoint">
                        <div class="endpoint-header">
                            <span class="endpoint-method GET">GET</span>
                            <span class="endpoint-url">/api/posts/list</span>
                        </div>
                        <div class="form-group">
                            <label>Page:</label>
                            <input type="number" id="posts_page" value="1" min="1">
                        </div>
                        <div class="form-group">
                            <label>Size:</label>
                            <input type="number" id="posts_size" value="10" min="1" max="100">
                        </div>
                        <button class="btn-test" onclick="if (!window.__cfRLUnblockHandlers) return false; testGetPosts()" data-cf-modified-96fb76fadccddadbbebeccf0-="">
                            <i class="fas fa-list"></i> Get Posts List
                        </button>
                        <div class="response-container" id="posts_response" style="display:none;"></div>
                    </div>

                    <div class="api-endpoint">
                        <div class="endpoint-header">
                            <span class="endpoint-method POST">POST</span>
                            <span class="endpoint-url">/api/posts/create</span>
                        </div>
                        <div class="form-group">
                            <label>Post Data (JSON):</label>
                            <textarea id="post_create_data" rows="8" placeholder='{"title": "Test Post", "content": "Test content", "subscriptionCode": "mangopulse", "postTypeCode": "article"}'></textarea>
                        </div>
                        <button class="btn-test" onclick="if (!window.__cfRLUnblockHandlers) return false; testCreatePost()" data-cf-modified-96fb76fadccddadbbebeccf0-="">
                            <i class="fas fa-plus"></i> Create Post
                        </button>
                        <div class="response-container" id="create_post_response" style="display:none;"></div>
                    </div>
                </div>
            </div>

            <!-- Users Tab -->
            <div class="tab-pane fade" id="users" role="tabpanel">
                <div class="api-section">
                    <h3><i class="fas fa-users"></i> Users APIs</h3>
                    
                    <div class="api-endpoint">
                        <div class="endpoint-header">
                            <span class="endpoint-method GET">GET</span>
                            <span class="endpoint-url">/api/users/list</span>
                        </div>
                        <button class="btn-test" onclick="if (!window.__cfRLUnblockHandlers) return false; testGetUsers()" data-cf-modified-96fb76fadccddadbbebeccf0-="">
                            <i class="fas fa-users"></i> Get Users List
                        </button>
                        <div class="response-container" id="users_response" style="display:none;"></div>
                    </div>

                    <div class="api-endpoint">
                        <div class="endpoint-header">
                            <span class="endpoint-method POST">POST</span>
                            <span class="endpoint-url">/api/users/create</span>
                        </div>
                        <div class="form-group">
                            <label>User Data (JSON):</label>
                            <textarea id="user_create_data" rows="6" placeholder='{"username": "testuser", "password": "password123", "firstName": "Test", "lastName": "User", "emailAddress": "test@example.com"}'></textarea>
                        </div>
                        <button class="btn-test" onclick="if (!window.__cfRLUnblockHandlers) return false; testCreateUser()" data-cf-modified-96fb76fadccddadbbebeccf0-="">
                            <i class="fas fa-user-plus"></i> Create User
                        </button>
                        <div class="response-container" id="create_user_response" style="display:none;"></div>
                    </div>
                </div>
            </div>

            <!-- Menus Tab -->
            <div class="tab-pane fade" id="menus" role="tabpanel">
                <div class="api-section">
                    <h3><i class="fas fa-bars"></i> Menus APIs</h3>
                    
                    <div class="api-endpoint">
                        <div class="endpoint-header">
                            <span class="endpoint-method GET">GET</span>
                            <span class="endpoint-url">/api/menus/list</span>
                        </div>
                        <button class="btn-test" onclick="if (!window.__cfRLUnblockHandlers) return false; testGetMenus()" data-cf-modified-96fb76fadccddadbbebeccf0-="">
                            <i class="fas fa-bars"></i> Get Menus List
                        </button>
                        <div class="response-container" id="menus_response" style="display:none;"></div>
                    </div>
                </div>
            </div>

            <!-- Widgets Tab -->
            <div class="tab-pane fade" id="widgets" role="tabpanel">
                <div class="api-section">
                    <h3><i class="fas fa-puzzle-piece"></i> Widgets APIs</h3>
                    
                    <div class="api-endpoint">
                        <div class="endpoint-header">
                            <span class="endpoint-method GET">GET</span>
                            <span class="endpoint-url">/api/widgets/list</span>
                        </div>
                        <button class="btn-test" onclick="if (!window.__cfRLUnblockHandlers) return false; testGetWidgets()" data-cf-modified-96fb76fadccddadbbebeccf0-="">
                            <i class="fas fa-puzzle-piece"></i> Get Widgets List
                        </button>
                        <div class="response-container" id="widgets_response" style="display:none;"></div>
                    </div>
                </div>
            </div>

            <!-- Health Tab -->
            <div class="tab-pane fade" id="health" role="tabpanel">
                <div class="api-section">
                    <h3><i class="fas fa-heartbeat"></i> Health Check APIs</h3>
                    
                    <div class="api-endpoint">
                        <div class="endpoint-header">
                            <span class="endpoint-method GET">GET</span>
                            <span class="endpoint-url">/health</span>
                        </div>
                        <button class="btn-test" onclick="if (!window.__cfRLUnblockHandlers) return false; testHealthCheck()" data-cf-modified-96fb76fadccddadbbebeccf0-="">
                            <i class="fas fa-heartbeat"></i> Check Health
                        </button>
                        <div class="response-container" id="health_response" style="display:none;"></div>
                    </div>
                </div>
            </div>
        </div>
    </div>
<script src="/cdn-cgi/scripts/7d0fa10a/cloudflare-static/rocket-loader.min.js" data-cf-settings="96fb76fadccddadbbebeccf0-|49" defer></script></body>
</html>
<script type="96fb76fadccddadbbebeccf0-text/javascript">
    const togglePassword = document.querySelector('#togglePassword');
    const password = document.querySelector('#password');

    togglePassword.addEventListener('click', function (e) {
        const type = password.getAttribute('type') === 'password' ? 'text' : 'password';
        password.setAttribute('type', type);

        this.classList.toggle('fa-eye');
        this.classList.toggle('fa-eye-slash');
    });

</script>

<!--


<div class="container" id="form_post_create_container" style="display:none;">
    <main>
        <div class="py-5 text-center">
            <img class="d-block mx-auto mb-4 admedia-logo" src="/imgs/admlogo.svg" alt="" width="72" height="57">
            <h2>Create Post form</h2>
            <p class="lead">This form is configured to use the subscription [ZAK] and the Post Type [article]</p>
        </div>
        <div class="row g-5">
            <div class="col-md-5 col-lg-4 order-md-last">
                <h4 class="d-flex justify-content-between align-items-center mb-3">
                    <span class="text-primary">Your Articles</span>
                    <span class="badge bg-primary rounded-pill">1</span>
                </h4>
                <ul class="list-group mb-3">
                    <li class="list-group-item d-flex justify-content-between lh-sm">
                        <div>
                            <h6 class="my-0">Article name</h6>
                            <small class="text-muted">Brief description</small>
                        </div>
                        <span class="text-muted"></span>
                    </li>

                </ul>
            </div>
            <div class="col-md-7 col-lg-8">
                <h4 class="mb-3">Create Post form</h4>
                <form class="needs-validation" novalidate id="form_post_create">



                    <div class="" id="form-inner">
                        <nav>
                            <div class="nav nav-tabs" id="nav-tab" role="tablist">
                                <button class="nav-link active" id="nav-main-fields-tab" data-bs-toggle="tab" data-bs-target="#nav-main-fields" type="button" role="tab">General</button>
                                <button class="nav-link" id="nav-metadata-tab" data-bs-toggle="tab" data-bs-target="#nav-meta" type="button" role="tab">Meta data</button>
                                <button class="nav-link" id="nav-grouping-tab" data-bs-toggle="tab" data-bs-target="#nav-term" type="button" role="tab">Grouping</button>
                                <button class="nav-link" id="nav-media-tab" data-bs-toggle="tab" data-bs-target="#nav-media" type="button" role="tab">Media</button>
                            </div>
                        </nav>
                        <div class="tab-content" id="nav-tabContent">
                            <div class="tab-pane fade show active row p-3" id="nav-main-fields" role="tabpanel">

                            </div>
                            <div class="tab-pane fade row p-3" id="nav-meta" role="tabpanel">

                            </div>
                            <div class="tab-pane fade row p-3" id="nav-term" role="tabpanel">

                            </div>
                            <div class="tab-pane fade row p-3" id="nav-media" role="tabpanel">
                                <div id="progress-wrp">
                                    <div class="progress-bar"></div>
                                    <div class="status">0%</div>
                                </div>
                            </div>
                        </div>
                    </div>
                    <hr class="my-4">
                    <button class="w-100 btn btn-primary btn-lg" type="button" id="btn_form_post_create">Save</button>
                </form>
            </div>

        </div>
    </main>

</div>
-->
