92a44faac3b1d6dbfeab803f342ccfc6b1b7219a
#22 Image overflow: added .frame(maxWidth: .infinity) before .frame(height: 180) on AsyncImage to constrain width within card. Card's .clipShape already clips corners. #23 Load more not triggering: added loadMoreIfNeeded(for:) that fires onAppear for entries 5 from the bottom. No longer relies solely on the bottom sentinel Color.clear which could be missed. Also increased sentinel height from 1pt to 40pt. #24 Refresh not updating read state: flushDeferredReads() now called before vm.refresh() in .refreshable. Deferred marks are synced to API before re-fetching, so the server returns correct read states. Also clears markedByScroll set. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Gitea CI Workflows
security.yml
Runs on push/PR to master. Three jobs:
- dependency-audit —
npm audit --audit-level=highfor budget and frontend - secret-scanning — checks for tracked .env/.db files and hardcoded secret patterns
- dockerfile-lint — verifies all Dockerfiles have
USER(non-root) andHEALTHCHECK
Runner Setup
The runner is configured in the Gitea docker-compose at /media/yusiboyz/Media/Scripts/gitea/docker-compose.yml.
What was done:
- Added
[actions] ENABLED = trueto Gitea'sapp.ini - Added
runnerservice (gitea/act_runner) to Gitea's docker-compose - Generated runner token via
docker exec -u git gitea gitea actions generate-runner-token - Token stored in
/media/yusiboyz/Media/Scripts/gitea/.envasRUNNER_TOKEN - Runner registered as
platform-runnerwith labels: ubuntu-latest, ubuntu-24.04, ubuntu-22.04
To regenerate token (if needed):
cd /media/yusiboyz/Media/Scripts/gitea
docker exec -u git gitea gitea actions generate-runner-token
# Update .env with new RUNNER_TOKEN value
docker compose up -d runner
To check runner status:
docker logs gitea-runner
Description
Languages
Svelte
51.2%
Python
24.2%
Swift
13.5%
JavaScript
5.4%
TypeScript
3.3%
Other
2.4%