- Rename test-apps to base-apps with proper manifest.json for each app - Add is_system_app flag to app discovery and Lua API - Fix icon path resolution for /system/icons/ paths - Add layout.lua and layout.rcss for reusable UI components - Update home screen to dynamically load all apps from manifests - Update all app RML files to use layout components - Comprehensive testing framework documentation with JSON action format - Add tests/ directory structure for automated UI testing
248 lines
7.0 KiB
Plaintext
248 lines
7.0 KiB
Plaintext
<rml>
|
|
<head>
|
|
<link type="text/rcss" href="../../ui/html.rcss"/>
|
|
<link type="text/rcss" href="../../ui/theme.rcss"/>
|
|
<link type="text/rcss" href="../../ui/components.rcss"/>
|
|
<link type="text/rcss" href="../../ui/layout.rcss"/>
|
|
<script src="../../scripts/navigation.lua"></script>
|
|
<script src="../../scripts/layout.lua"></script>
|
|
<title>Browser</title>
|
|
<style>
|
|
.browser-toolbar {
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 8px;
|
|
background-color: #1E1E1E;
|
|
gap: 8px;
|
|
}
|
|
|
|
.browser-nav-btn {
|
|
width: 48px;
|
|
height: 48px;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
cursor: pointer;
|
|
border-radius: 24px;
|
|
}
|
|
|
|
.browser-nav-btn:hover {
|
|
background-color: rgba(255, 255, 255, 0.1);
|
|
}
|
|
|
|
.browser-nav-btn img {
|
|
width: 28px;
|
|
height: 28px;
|
|
}
|
|
|
|
.browser-nav-btn.disabled img {
|
|
opacity: 0.3;
|
|
}
|
|
|
|
.browser-url-bar {
|
|
flex: 1;
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 10px 16px;
|
|
background-color: #2D2D2D;
|
|
border-radius: 20px;
|
|
}
|
|
|
|
.browser-secure-icon {
|
|
font-size: 16px;
|
|
color: #4CAF50;
|
|
margin-right: 8px;
|
|
}
|
|
|
|
.browser-url {
|
|
flex: 1;
|
|
font-size: 16px;
|
|
color: #FFFFFF;
|
|
background: transparent;
|
|
border: none;
|
|
}
|
|
|
|
.browser-content {
|
|
flex: 1;
|
|
background-color: #FFFFFF;
|
|
overflow: auto;
|
|
}
|
|
|
|
.browser-page {
|
|
padding: 16px;
|
|
color: #000000;
|
|
}
|
|
|
|
.browser-page-title {
|
|
font-size: 24px;
|
|
font-weight: bold;
|
|
color: #1a0dab;
|
|
margin-bottom: 16px;
|
|
}
|
|
|
|
.browser-page-text {
|
|
font-size: 16px;
|
|
line-height: 1.6;
|
|
color: #333333;
|
|
margin-bottom: 16px;
|
|
}
|
|
|
|
.browser-page-link {
|
|
color: #1a0dab;
|
|
cursor: pointer;
|
|
}
|
|
|
|
.browser-page-link:hover {
|
|
text-decoration: underline;
|
|
}
|
|
|
|
.browser-search-item {
|
|
margin-bottom: 20px;
|
|
cursor: pointer;
|
|
padding: 8px;
|
|
border-radius: 8px;
|
|
}
|
|
|
|
.browser-search-item:hover {
|
|
background-color: #f0f0f0;
|
|
}
|
|
|
|
.browser-search-title {
|
|
font-size: 18px;
|
|
color: #1a0dab;
|
|
margin-bottom: 4px;
|
|
}
|
|
|
|
.browser-search-url {
|
|
font-size: 14px;
|
|
color: #006621;
|
|
margin-bottom: 4px;
|
|
}
|
|
|
|
.browser-search-desc {
|
|
font-size: 16px;
|
|
color: #545454;
|
|
line-height: 1.4;
|
|
}
|
|
|
|
.browser-bottom-bar {
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 8px 16px;
|
|
background-color: #1E1E1E;
|
|
border-top: 1px solid #333333;
|
|
}
|
|
|
|
.browser-tab-btn {
|
|
flex: 1;
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
padding: 8px;
|
|
cursor: pointer;
|
|
color: #B3B3B3;
|
|
}
|
|
|
|
.browser-tab-btn:hover {
|
|
color: #FFFFFF;
|
|
}
|
|
|
|
.browser-tab-btn img {
|
|
width: 28px;
|
|
height: 28px;
|
|
margin-bottom: 4px;
|
|
}
|
|
|
|
.browser-tab-btn span {
|
|
font-size: 14px;
|
|
}
|
|
|
|
.browser-tabs-indicator {
|
|
padding: 6px 10px;
|
|
border: 1px solid #B3B3B3;
|
|
border-radius: 6px;
|
|
font-size: 14px;
|
|
color: #B3B3B3;
|
|
}
|
|
</style>
|
|
</head>
|
|
<body class="app-screen" onload="initLayout(document)" data-model="browser">
|
|
<!-- System Status Bar -->
|
|
<div class="system-status-bar">
|
|
<span id="status-time" class="system-status-time">12:30</span>
|
|
<div class="system-status-icons">
|
|
<img src="../../icons/wifi.tga"/>
|
|
<img src="../../icons/signal.tga"/>
|
|
<img src="../../icons/battery.tga"/>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Browser Toolbar -->
|
|
<div class="browser-toolbar">
|
|
<div class="browser-nav-btn" onclick="goBack()">
|
|
<img src="../../icons/back.tga"/>
|
|
</div>
|
|
<div class="browser-nav-btn disabled">
|
|
<img src="../../icons/forward.tga"/>
|
|
</div>
|
|
<div class="browser-url-bar">
|
|
<span class="browser-secure-icon">S</span>
|
|
<input class="browser-url" type="text" value="example.com"/>
|
|
</div>
|
|
<div class="browser-nav-btn">
|
|
<img src="../../icons/refresh.tga"/>
|
|
</div>
|
|
<div class="browser-nav-btn">
|
|
<img src="../../icons/more.tga"/>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Browser Content -->
|
|
<div class="browser-content">
|
|
<div class="browser-page">
|
|
<div class="browser-page-title">Example Domain</div>
|
|
<div class="browser-page-text">
|
|
This domain is for use in illustrative examples in documents. You may use this domain in literature without prior coordination or asking for permission.
|
|
</div>
|
|
<div class="browser-page-text">
|
|
<span class="browser-page-link">More information...</span>
|
|
</div>
|
|
|
|
<div style="margin-top: 32px; padding-top: 16px; border-top: 1px solid #e0e0e0;">
|
|
<div class="browser-page-title" style="font-size: 18px;">Related Links</div>
|
|
<div class="browser-search-item">
|
|
<div class="browser-search-title">IANA - IANA-managed Reserved Domains</div>
|
|
<div class="browser-search-url">www.iana.org > domains > reserved</div>
|
|
<div class="browser-search-desc">Certain domains are set aside and unavailable for registration.</div>
|
|
</div>
|
|
<div class="browser-search-item">
|
|
<div class="browser-search-title">RFC 2606 - Reserved Top Level DNS Names</div>
|
|
<div class="browser-search-url">tools.ietf.org > html > rfc2606</div>
|
|
<div class="browser-search-desc">This document describes domain names reserved for documentation.</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Bottom Bar -->
|
|
<div class="browser-bottom-bar">
|
|
<div class="browser-tab-btn" onclick="goHome()">
|
|
<img src="../../icons/home.tga"/>
|
|
<span>Home</span>
|
|
</div>
|
|
<div class="browser-tab-btn">
|
|
<span class="browser-tabs-indicator">1</span>
|
|
<span>Tabs</span>
|
|
</div>
|
|
<div class="browser-tab-btn">
|
|
<img src="../../icons/add.tga"/>
|
|
<span>New Tab</span>
|
|
</div>
|
|
<div class="browser-tab-btn">
|
|
<img src="../../icons/menu.tga"/>
|
|
<span>Menu</span>
|
|
</div>
|
|
</div>
|
|
</body>
|
|
</rml>
|