Skip to content

Commit

Permalink
add: nanoui
Browse files Browse the repository at this point in the history
  • Loading branch information
Furrior committed Feb 1, 2025
1 parent acb808c commit ff30c1b
Show file tree
Hide file tree
Showing 6 changed files with 1,244 additions and 0 deletions.
2 changes: 2 additions & 0 deletions app/main.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
from fastapi import FastAPI, status
from fastapi.concurrency import asynccontextmanager
from fastapi.responses import FileResponse
from fastapi.staticfiles import StaticFiles

from app.core.config import CONFIG
from app.init import init
Expand All @@ -17,6 +18,7 @@ async def lifespan(_: FastAPI):
description=CONFIG.general.project_desc,
lifespan=lifespan
)
app.mount("/nanoui", StaticFiles(directory="app/public/nanoui"), name="nanoui")
app.include_router(v1_router)


Expand Down
352 changes: 352 additions & 0 deletions app/public/nanoui/css/icons.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,352 @@
/* Icons
----------------------------------*/

.icon24
{
width: 24px;
height: 24px;
}

.icon24.uiStatusGood
{
background: url(https://github.com/ss220club/WyccerraBay220/blob/master/nano/images/uiIcons24.png?raw=true) 0 0 no-repeat;
}

.icon24.uiStatusAverage
{
background: url(https://github.com/ss220club/WyccerraBay220/blob/master/nano/images/uiIcons24.png?raw=true) 0 -24px no-repeat;
}

.icon24.uiStatusBad
{
background: url(https://github.com/ss220club/WyccerraBay220/blob/master/nano/images/uiIcons24.png?raw=true) 0 -48px no-repeat;
}

/* states and images */
.uiIcon16 {
float: left;
width: 16px;
height: 16px;
margin: 2px 2px 0 2px;
background-image: url(https://github.com/ss220club/WyccerraBay220/blob/master/nano/images/uiIcons16.png?raw=true);
}

.uiLinkPendingIcon {
display: none;
float: left;
width: 16px;
height: 16px;
margin: 2px 2px 0 2px;
background-image: url(https://github.com/ss220club/WyccerraBay220/blob/master/nano/images/uiLinkPendingIcon.gif?raw=true);
}

.linkPending .uiIcon16 {
display: none;
}

.linkPending .uiLinkPendingIcon {
display: block;
}

/* positioning */
.uiIcon16.icon-blank { background-position: 16px 16px; }
.uiIcon16.icon-carat-1-n { background-position: 0 0; }
.uiIcon16.icon-carat-1-ne { background-position: -16px 0; }
.uiIcon16.icon-carat-1-e { background-position: -32px 0; }
.uiIcon16.icon-carat-1-se { background-position: -48px 0; }
.uiIcon16.icon-carat-1-s { background-position: -64px 0; }
.uiIcon16.icon-carat-1-sw { background-position: -80px 0; }
.uiIcon16.icon-carat-1-w { background-position: -96px 0; }
.uiIcon16.icon-carat-1-nw { background-position: -112px 0; }
.uiIcon16.icon-carat-2-n-s { background-position: -128px 0; }
.uiIcon16.icon-carat-2-e-w { background-position: -144px 0; }
.uiIcon16.icon-triangle-1-n { background-position: 0 -16px; }
.uiIcon16.icon-triangle-1-ne { background-position: -16px -16px; }
.uiIcon16.icon-triangle-1-e { background-position: -32px -16px; }
.uiIcon16.icon-triangle-1-se { background-position: -48px -16px; }
.uiIcon16.icon-triangle-1-s { background-position: -64px -16px; }
.uiIcon16.icon-triangle-1-sw { background-position: -80px -16px; }
.uiIcon16.icon-triangle-1-w { background-position: -96px -16px; }
.uiIcon16.icon-triangle-1-nw { background-position: -112px -16px; }
.uiIcon16.icon-triangle-2-n-s { background-position: -128px -16px; }
.uiIcon16.icon-triangle-2-e-w { background-position: -144px -16px; }
.uiIcon16.icon-arrow-1-n { background-position: 0 -32px; }
.uiIcon16.icon-arrow-1-ne { background-position: -16px -32px; }
.uiIcon16.icon-arrow-1-e { background-position: -32px -32px; }
.uiIcon16.icon-arrow-1-se { background-position: -48px -32px; }
.uiIcon16.icon-arrow-1-s { background-position: -64px -32px; }
.uiIcon16.icon-arrow-1-sw { background-position: -80px -32px; }
.uiIcon16.icon-arrow-1-w { background-position: -96px -32px; }
.uiIcon16.icon-arrow-1-nw { background-position: -112px -32px; }
.uiIcon16.icon-arrow-2-n-s { background-position: -128px -32px; }
.uiIcon16.icon-arrow-2-ne-sw { background-position: -144px -32px; }
.uiIcon16.icon-arrow-2-e-w { background-position: -160px -32px; }
.uiIcon16.icon-arrow-2-se-nw { background-position: -176px -32px; }
.uiIcon16.icon-arrowstop-1-n { background-position: -192px -32px; }
.uiIcon16.icon-arrowstop-1-e { background-position: -208px -32px; }
.uiIcon16.icon-arrowstop-1-s { background-position: -224px -32px; }
.uiIcon16.icon-arrowstop-1-w { background-position: -240px -32px; }
.uiIcon16.icon-arrowthick-1-n { background-position: 0 -48px; }
.uiIcon16.icon-arrowthick-1-ne { background-position: -16px -48px; }
.uiIcon16.icon-arrowthick-1-e { background-position: -32px -48px; }
.uiIcon16.icon-arrowthick-1-se { background-position: -48px -48px; }
.uiIcon16.icon-arrowthick-1-s { background-position: -64px -48px; }
.uiIcon16.icon-arrowthick-1-sw { background-position: -80px -48px; }
.uiIcon16.icon-arrowthick-1-w { background-position: -96px -48px; }
.uiIcon16.icon-arrowthick-1-nw { background-position: -112px -48px; }
.uiIcon16.icon-arrowthick-2-n-s { background-position: -128px -48px; }
.uiIcon16.icon-arrowthick-2-ne-sw { background-position: -144px -48px; }
.uiIcon16.icon-arrowthick-2-e-w { background-position: -160px -48px; }
.uiIcon16.icon-arrowthick-2-se-nw { background-position: -176px -48px; }
.uiIcon16.icon-arrowthickstop-1-n { background-position: -192px -48px; }
.uiIcon16.icon-arrowthickstop-1-e { background-position: -208px -48px; }
.uiIcon16.icon-arrowthickstop-1-s { background-position: -224px -48px; }
.uiIcon16.icon-arrowthickstop-1-w { background-position: -240px -48px; }
.uiIcon16.icon-arrowreturnthick-1-w { background-position: 0 -64px; }
.uiIcon16.icon-arrowreturnthick-1-n { background-position: -16px -64px; }
.uiIcon16.icon-arrowreturnthick-1-e { background-position: -32px -64px; }
.uiIcon16.icon-arrowreturnthick-1-s { background-position: -48px -64px; }
.uiIcon16.icon-arrowreturn-1-w { background-position: -64px -64px; }
.uiIcon16.icon-arrowreturn-1-n { background-position: -80px -64px; }
.uiIcon16.icon-arrowreturn-1-e { background-position: -96px -64px; }
.uiIcon16.icon-arrowreturn-1-s { background-position: -112px -64px; }
.uiIcon16.icon-arrowrefresh-1-w { background-position: -128px -64px; }
.uiIcon16.icon-arrowrefresh-1-n { background-position: -144px -64px; }
.uiIcon16.icon-arrowrefresh-1-e { background-position: -160px -64px; }
.uiIcon16.icon-arrowrefresh-1-s { background-position: -176px -64px; }
.uiIcon16.icon-arrow-4 { background-position: 0 -80px; }
.uiIcon16.icon-arrow-4-diag { background-position: -16px -80px; }
.uiIcon16.icon-extlink { background-position: -32px -80px; }
.uiIcon16.icon-newwin { background-position: -48px -80px; }
.uiIcon16.icon-refresh { background-position: -64px -80px; }
.uiIcon16.icon-shuffle { background-position: -80px -80px; }
.uiIcon16.icon-transfer-e-w { background-position: -96px -80px; }
.uiIcon16.icon-transferthick-e-w { background-position: -112px -80px; }
.uiIcon16.icon-radiation { background-position: -128px -80px; }
.uiIcon16.icon-biohazard { background-position: -144px -80px;}
.uiIcon16.icon-first-aid { background-position: -160px -80px;}
.uiIcon16.icon-square { background-position: -176px -80px;}
.uiIcon16.icon-check-square { background-position: -192px -80px;}
.uiIcon16.icon-folder-collapsed { background-position: 0 -96px; }
.uiIcon16.icon-folder-open { background-position: -16px -96px; }
.uiIcon16.icon-document { background-position: -32px -96px; }
.uiIcon16.icon-document-b { background-position: -48px -96px; }
.uiIcon16.icon-note { background-position: -64px -96px; }
.uiIcon16.icon-mail-closed { background-position: -80px -96px; }
.uiIcon16.icon-mail-open { background-position: -96px -96px; }
.uiIcon16.icon-suitcase { background-position: -112px -96px; }
.uiIcon16.icon-comment { background-position: -128px -96px; }
.uiIcon16.icon-person { background-position: -144px -96px; }
.uiIcon16.icon-print { background-position: -160px -96px; }
.uiIcon16.icon-trash { background-position: -176px -96px; }
.uiIcon16.icon-locked { background-position: -192px -96px; }
.uiIcon16.icon-unlocked { background-position: -208px -96px; }
.uiIcon16.icon-bookmark { background-position: -224px -96px; }
.uiIcon16.icon-tag { background-position: -240px -96px; }
.uiIcon16.icon-home { background-position: 0 -112px; }
.uiIcon16.icon-flag { background-position: -16px -112px; }
.uiIcon16.icon-calendar { background-position: -32px -112px; }
.uiIcon16.icon-cart { background-position: -48px -112px; }
.uiIcon16.icon-pencil { background-position: -64px -112px; }
.uiIcon16.icon-clock { background-position: -80px -112px; }
.uiIcon16.icon-disk { background-position: -96px -112px; }
.uiIcon16.icon-calculator { background-position: -112px -112px; }
.uiIcon16.icon-zoomin { background-position: -128px -112px; }
.uiIcon16.icon-zoomout { background-position: -144px -112px; }
.uiIcon16.icon-search { background-position: -160px -112px; }
.uiIcon16.icon-wrench { background-position: -176px -112px; }
.uiIcon16.icon-gear { background-position: -192px -112px; }
.uiIcon16.icon-heart { background-position: -208px -112px; }
.uiIcon16.icon-star { background-position: -224px -112px; }
.uiIcon16.icon-link { background-position: -240px -112px; }
.uiIcon16.icon-cancel { background-position: 0 -128px; }
.uiIcon16.icon-plus { background-position: -16px -128px; }
.uiIcon16.icon-plusthick { background-position: -32px -128px; }
.uiIcon16.icon-minus { background-position: -48px -128px; }
.uiIcon16.icon-minusthick { background-position: -64px -128px; }
.uiIcon16.icon-close { background-position: -80px -128px; }
.uiIcon16.icon-closethick { background-position: -96px -128px; }
.uiIcon16.icon-key { background-position: -112px -128px; }
.uiIcon16.icon-lightbulb { background-position: -128px -128px; }
.uiIcon16.icon-scissors { background-position: -144px -128px; }
.uiIcon16.icon-clipboard { background-position: -160px -128px; }
.uiIcon16.icon-copy { background-position: -176px -128px; }
.uiIcon16.icon-contact { background-position: -192px -128px; }
.uiIcon16.icon-image { background-position: -208px -128px; }
.uiIcon16.icon-video { background-position: -224px -128px; }
.uiIcon16.icon-script { background-position: -240px -128px; }
.uiIcon16.icon-alert { background-position: 0 -144px; }
.uiIcon16.icon-info { background-position: -16px -144px; }
.uiIcon16.icon-notice { background-position: -32px -144px; }
.uiIcon16.icon-help { background-position: -48px -144px; }
.uiIcon16.icon-check { background-position: -64px -144px; }
.uiIcon16.icon-bullet { background-position: -80px -144px; }
.uiIcon16.icon-radio-on { background-position: -96px -144px; }
.uiIcon16.icon-radio-off { background-position: -112px -144px; }
.uiIcon16.icon-pin-w { background-position: -128px -144px; }
.uiIcon16.icon-pin-s { background-position: -144px -144px; }
.uiIcon16.icon-syringe { background-position: -192px -144px; }
.uiIcon16.icon-play { background-position: 0 -160px; }
.uiIcon16.icon-pause { background-position: -16px -160px; }
.uiIcon16.icon-seek-next { background-position: -32px -160px; }
.uiIcon16.icon-seek-prev { background-position: -48px -160px; }
.uiIcon16.icon-seek-end { background-position: -64px -160px; }
.uiIcon16.icon-seek-start { background-position: -80px -160px; }
/* uiIcon-seek-first is deprecated, use uiIcon-seek-start instead */
.uiIcon16.icon-seek-first { background-position: -80px -160px; }
.uiIcon16.icon-stop { background-position: -96px -160px; }
.uiIcon16.icon-eject { background-position: -112px -160px; }
.uiIcon16.icon-volume-off { background-position: -128px -160px; }
.uiIcon16.icon-volume-on { background-position: -144px -160px; }
.uiIcon16.icon-power { background-position: 0 -176px; }
.uiIcon16.icon-signal-diag { background-position: -16px -176px; }
.uiIcon16.icon-signal { background-position: -32px -176px; }
.uiIcon16.icon-battery-0 { background-position: -48px -176px; }
.uiIcon16.icon-battery-1 { background-position: -64px -176px; }
.uiIcon16.icon-battery-2 { background-position: -80px -176px; }
.uiIcon16.icon-battery-3 { background-position: -96px -176px; }
.uiIcon16.icon-circle-plus { background-position: 0 -192px; }
.uiIcon16.icon-circle-minus { background-position: -16px -192px; }
.uiIcon16.icon-circle-close { background-position: -32px -192px; }
.uiIcon16.icon-circle-triangle-e { background-position: -48px -192px; }
.uiIcon16.icon-circle-triangle-s { background-position: -64px -192px; }
.uiIcon16.icon-circle-triangle-w { background-position: -80px -192px; }
.uiIcon16.icon-circle-triangle-n { background-position: -96px -192px; }
.uiIcon16.icon-circle-arrow-e { background-position: -112px -192px; }
.uiIcon16.icon-circle-arrow-s { background-position: -128px -192px; }
.uiIcon16.icon-circle-arrow-w { background-position: -144px -192px; }
.uiIcon16.icon-circle-arrow-n { background-position: -160px -192px; }
.uiIcon16.icon-circle-zoomin { background-position: -176px -192px; }
.uiIcon16.icon-circle-zoomout { background-position: -192px -192px; }
.uiIcon16.icon-circle-check { background-position: -208px -192px; }
.uiIcon16.icon-circlesmall-plus { background-position: 0 -208px; }
.uiIcon16.icon-circlesmall-minus { background-position: -16px -208px; }
.uiIcon16.icon-circlesmall-close { background-position: -32px -208px; }
.uiIcon16.icon-squaresmall-plus { background-position: -48px -208px; }
.uiIcon16.icon-squaresmall-minus { background-position: -64px -208px; }
.uiIcon16.icon-squaresmall-close { background-position: -80px -208px; }
.uiIcon16.icon-grip-dotted-vertical { background-position: 0 -224px; }
.uiIcon16.icon-grip-dotted-horizontal { background-position: -16px -224px; }
.uiIcon16.icon-grip-solid-vertical { background-position: -32px -224px; }
.uiIcon16.icon-grip-solid-horizontal { background-position: -48px -224px; }
.uiIcon16.icon-gripsmall-diagonal-se { background-position: -64px -224px; }
.uiIcon16.icon-grip-diagonal-se { background-position: -80px -224px; }
.uiIcon16.icon-batt_full { background-image: url(../images/c_max.gif); background-position: 0px 0px }
.uiIcon16.icon-batt_disc { background-image: url(../images/c_discharging.gif); background-position: 0px 0px }
.uiIcon16.icon-batt_chrg { background-image: url(../images/c_charging.gif); background-position: 0px 0px }
.uiIcon16.icon-close64 { background-image: url(https://github.com/ss220club/WyccerraBay220/blob/master/nano/images/uiIcons64.png?raw=true); background-position: -128px -64px; width: 64px; height: 64px; }

.mapIcon16 {
position: absolute;
width: 16px;
height: 16px;
background-image: url(https://github.com/ss220club/WyccerraBay220/blob/master/nano/images/uiIcons16Green.png?raw=true);
background-position: -48px -112px; /* Question Mark */
background-repeat: no-repeat;
zoom: 0.125;
margin-left: -1px;
/*margin-bottom: -1px;*/
}
.mapIcon16.dead {
background-image: url(https://github.com/ss220club/WyccerraBay220/blob/master/nano/images/uiIcons16Red.png?raw=true);
}

/* Command Positions - Star */
.mapIcon16.rank-captain,
.mapIcon16.rank-commandingofficer,
.mapIcon16.rank-executiveofficer
{
background-position: -224px -112px;
}

/* Command Support Positions - Chainlink */
.mapIcon16.rank-headofpersonnel,
.mapIcon16.rank-bridgeofficer,
.mapIcon16.rank-internalaffairsagent,
.mapIcon16.rank-solgovrepresentative,
.mapIcon16.rank-seniorenlistedadvisor,
.mapIcon16.rank-workplaceliaison
{
background-position: -240 -112px;
}

/* Engineering Positions - Wrench */
.mapIcon16.rank-chiefengineer,
.mapIcon16.rank-engineer,
.mapIcon16.rank-atmospherictechnician,
.mapIcon16.rank-seniorengineer,
.mapIcon16.rank-engineertrainee,
.mapIcon16.rank-roboticist
{
background-position: -176px -112px;
}

/* Medical Positions - Plus */
.mapIcon16.rank-chiefmedicalofficer,
.mapIcon16.rank-medicaldoctor,
.mapIcon16.rank-geneticist,
.mapIcon16.rank-psychiatrist,
.mapIcon16.rank-pharmacist,
.mapIcon16.rank-paramedic,
.mapIcon16.rank-physician,
.mapIcon16.rank-medicalresident,
.mapIcon16.rank-medicaltechnician,
.mapIcon16.rank-traineemedicaltechnician,
.mapIcon16.rank-counselor
{
background-position: -32px -128px;
}

/* Science Positions - Lightbulb */
.mapIcon16.rank-chiefscienceofficer,
.mapIcon16.rank-researchdirector,
.mapIcon16.rank-scientist,
.mapIcon16.rank-geneticist,
.mapIcon16.rank-xenobiologist,
.mapIcon16.rank-seniorresearcher,
.mapIcon16.rank-researchassistant
{
background-position: -128px -128px;
}

/* Security Positions - Key */
.mapIcon16.rank-headofsecurity,
.mapIcon16.rank-chiefofsecurity,
.mapIcon16.rank-warden,
.mapIcon16.rank-detective,
.mapIcon16.rank-securityofficer,
.mapIcon16.rank-brigchief,
.mapIcon16.rank-forensictechnician,
.mapIcon16.rank-masteratarms
{
background-position: -112px -128px;
}

/* Exploration Positions - Flag */
.mapIcon16.rank-pathfinder,
.mapIcon16.rank-shuttle-pilot,
.mapIcon16.rank-explorer
{
background-position: -16px -112px
}

/* Other Crew - Person */
.mapIcon16.rank-assistant,
.mapIcon16.rank-cargotechnician,
.mapIcon16.rank-janitor,
.mapIcon16.rank-shaftminer
.mapIcon16.rank-bartender,
.mapIcon16.rank-cook,
.mapIcon16.rank-passenger,
.mapIcon16.rank-chiefsteward,
.mapIcon16.rank-chaplain,
.mapIcon16.rank-sanitation,
.mapIcon16.rank-technician,
.mapIcon16.rank-steward,
.mapIcon16.rank-crewman,
.mapIcon16.rank-deckchief,
.mapIcon16.rank-decktechnician,
.mapIcon16.rank-prospector
{
background-position: -144px -96px;
}
21 changes: 21 additions & 0 deletions app/public/nanoui/css/layout_basic.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
body {
background: #272727 url(https://github.com/ss220club/WyccerraBay220/blob/master/nano/images/uiBasicBackground.png?raw=true) 50% 0 repeat-x;
}

#uiContent {
clear: both;
padding: 8px;
}

#uiLoadingNotice {
position: relative;
background: url(https://github.com/ss220club/WyccerraBay220/blob/master/nano/images/uiNoticeBackground.jpg?raw=true) 50% 50%;
color: #000000;
font-size: 14px;
font-style: italic;
font-weight: bold;
padding: 3px 4px 3px 4px;
margin: 4px 0 4px 0;
}


Loading

0 comments on commit ff30c1b

Please sign in to comment.