Skip to content
/ qwikkin Public template
forked from onwidget/qwind

πŸš€πŸ’¨ Qwikkin: A template to make a user application utilizing the Qwik framework with Tailwind CSS for the client hosted via KinodeOS

License

Notifications You must be signed in to change notification settings

unenunciate/qwikkin

Β 
Β 

Repository files navigation

Qwikkin

Qwikkin is a free and open-source template to make your website using Qwik + Tailwind CSS and hosting via KinodeOS node for the frontend presentation for a KinodeOS application. Ready to start a new project and designed taking into account best practices.

Features

  • βœ… Integration with Tailwind CSS supporting Dark mode
  • βœ… Integration with Farcaster Frames and ReFrame expansion
  • βœ… Integration with Coinbase Smart Wallet, OnChainKit, and Base
  • βœ… Integration with SIWE
  • βœ… Integration with Ceramic Network and OrbisDB
  • βœ… Basic Implementation of ClientDB
  • βœ… Backwards compatiblity with traditional link previews and handling via public gateway

//To Do: Screenshot

Qwikkin Theme Screenshot

//To Do: Logos/License/Contribuations/Know Issues

onWidget License Maintained Contributions Welcome Known Vulnerabilities


Table of Contents

Demo

πŸ“Œ https://qwikkin.unenunciate.com/


Getting started

This project is using Qwik with QwikCity. QwikCity is just a extra set of tools on top of Qwik to make it easier to build a full site, including directory-based routing, layouts, and more.

Project structure

Inside Qwikkin template, you'll see the following folders and files:

/
β”œβ”€β”€ adaptors/
|   └── static/
|       └── vite.config.ts
β”œβ”€β”€ public/
β”‚   β”œβ”€β”€ favicon.svg
β”‚   β”œβ”€β”€ manifest.json
β”‚   └── robots.txt
β”œβ”€β”€ src/
β”‚   β”œβ”€β”€ assets/
β”‚   β”‚   β”œβ”€β”€ images/
|   |   └── styles/
|   |       └── global.css
β”‚   β”œβ”€β”€ components/
β”‚   β”‚   β”œβ”€β”€ atoms/
β”‚   β”‚   β”œβ”€β”€ core/
β”‚   β”‚   β”œβ”€β”€ icons/
|   |   └── widgets/
|   |       β”œβ”€β”€ Hero.tsx
|   |       β”œβ”€β”€ Features.tsx
|   |       └── ...
β”‚   β”œβ”€β”€ content/
β”‚   |   └── blog/
β”‚   |       β”œβ”€β”€ post-slug-1.md
β”‚   |       β”œβ”€β”€ post-slug-2.md
β”‚   |       └── ...
β”‚   β”œβ”€β”€ routes/
β”‚   |   β”œβ”€β”€ blog/
β”‚   |   β”œβ”€β”€ index.tsx
|   |   β”œβ”€β”€ layout.tsx
|   |   β”œ-- service-worker.ts
β”‚   |   β””-- ...
β”‚   β”œβ”€β”€ config.mjs
β”‚   β”œβ”€β”€ entry.dev.tsx
β”‚   β”œβ”€β”€ entry.preview.tsx
β”‚   β”œβ”€β”€ entry.ssr.tsx
β”‚   └── root.tsx
β”œβ”€β”€ package.json
└── ...
  • src/routes: Provides the directory based routing, which can include a hierarchy of layout.tsx layout files, and an index.tsx file as the page. Additionally, index.ts files are endpoints. Please see the routing docs for more info.

  • src/components: Recommended directory for components.

  • public: Any static assets, like images, can be placed in the public directory. Please see the Vite public directory for more info.

//To Do: Make a CodeSandbox if possible with KinodeOS

Edit Qwikkin on CodeSandbox

Seasoned qwik expert? Delete this file. Update config.mjs and contents. Have fun!


//To Do: Add Yarn + Add Kinode Commands

Commands

All commands are run from the root of the project, from a terminal:

Command Action
npm install Installs dependencies
npm run dev Starts local dev server at 127.0.0.1:5173/
npm run build Build your production site to ./dist/
npm run preview Preview your build locally, before deploying
npm run fmt Format codes with Prettier
npm run lint Run Eslint
npm run qwik ... Run CLI commands like qwik add, qwik build

Configuration

//To Do: Define config properties

Basic configuration file: ./src/config.mjs

export const SITE = {
  name: "Example",

  origin: "https://example.com",
  basePathname: "/", // Change this if you need to deploy to Github Pages, for example
  trailingSlash: true, // Generate permalinks with or without "/" at the end
};

Deploy

//TO DO: All Instructions

Deploy to Devlopment Enviorment

Deploy KinodeOS Application

Deploy KinodeOS Node & Installing KinodeOS Application (via Kinode Vallet)

Deploy KinodeOS Node as Public Application Gateway (via AWS)

You can create an optimized production build with:

npm run build //TO DO

Now, your website is ready to be deployed. All generated files are located at dist folder, which you can deploy the folder to any hosting service you prefer.


Roadmap

Base

  • Create utilities to generate permalinks tailored to the domain and base pathname.
  • Create utilities to generate IPFS pinned Farcaster Frames tailored to context and user customizations.
  • Create utilities to enable switching between media content's hosting location (Traditional Cloud Vs. dStorage [IPFS/Storj] + dDistrobution [Crust Network])
  • Create basic context system for referencing elements of content
  • Create basic context system visualization
  • Create component to enable building sharing frames and contextual frames via client
  • Create configurable blog with categories, tags and authors using MDX
  • Authentication via SIWE and Coinbase Smart Wallet
  • Add more frequently used pages (About, Services, Contact, Docs ...)
  • Inital ClientDB intergration
  • Link previews, frame portal, and IPFS Gateway via hosted domain utilized for backwards compatiablity to resolve frames stored on IPFS without the link's frontend client requiring special handling (URL format: https://domain.example/frame-portal/:CID)

Advanced

  • Create component to enable building custom frames via client
  • Create multimedia context system
  • Sitemap and SEO Improvements
  • ClientDB Basic Fog of Data Optimization
  • Utilize Oasis OPL Layer in Attributation system
  • Create advanaced visualization of context system
  • Add Multi-tab Service Work Leader Elections
  • ClientDB Advanced Fog of Data Optimization and Service worker optimization
  • Define a KinodeOS mode for operating as centralized public gateway and service still as a KinodeOS app
  • Admin backend for operating as centralized public platform
  • Traui Desktop Application
  • ClientDB Traui Intergration
  • Mobile Application and ClientDB SQLite

Contributing

If you have any idea, suggestions or find any bugs, feel free to open a discussion, an issue or create a pull request. That would be very useful for all of us and we would be happy to listen and take action.

Acknowledgements

Initially created and maintained by Unenunciate X

License

Qwikkin is licensed under the MIT license β€” see the LICENSE file for details.

About

πŸš€πŸ’¨ Qwikkin: A template to make a user application utilizing the Qwik framework with Tailwind CSS for the client hosted via KinodeOS

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 93.8%
  • JavaScript 3.8%
  • CSS 2.4%