{"id":23014822,"url":"https://github.com/juliankrzysiak/jeblore","last_synced_at":"2025-04-02T17:43:25.878Z","repository":{"id":263064344,"uuid":"887741145","full_name":"juliankrzysiak/jeblore","owner":"juliankrzysiak","description":"A website for hosting jeblore comics","archived":false,"fork":false,"pushed_at":"2025-03-24T04:29:37.000Z","size":5999,"stargazers_count":0,"open_issues_count":3,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-03-24T05:28:06.038Z","etag":null,"topics":["art","astro","cms","keystatic","webcomic","webcomics-platform"],"latest_commit_sha":null,"homepage":"https://jeblore.com","language":"Astro","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"other","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/juliankrzysiak.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE.txt","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-11-13T07:49:29.000Z","updated_at":"2025-03-24T04:29:41.000Z","dependencies_parsed_at":"2024-11-15T23:20:34.657Z","dependency_job_id":"38273f19-6f0f-42c3-ac29-99faad0f13b1","html_url":"https://github.com/juliankrzysiak/jeblore","commit_stats":null,"previous_names":["juliankrzysiak/jeblore"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/juliankrzysiak%2Fjeblore","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/juliankrzysiak%2Fjeblore/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/juliankrzysiak%2Fjeblore/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/juliankrzysiak%2Fjeblore/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/juliankrzysiak","download_url":"https://codeload.github.com/juliankrzysiak/jeblore/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":246863902,"owners_count":20846334,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["art","astro","cms","keystatic","webcomic","webcomics-platform"],"created_at":"2024-12-15T11:09:54.625Z","updated_at":"2025-04-02T17:43:25.862Z","avatar_url":"https://github.com/juliankrzysiak.png","language":"Astro","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003c!-- Improved compatibility of back to top link: See: https://github.com/othneildrew/Best-README-Template/pull/73 --\u003e\n\u003ca id=\"readme-top\"\u003e\u003c/a\u003e\n\u003c!--\n*** Thanks for checking out the Best-README-Template. If you have a suggestion\n*** that would make this better, please fork the repo and create a pull request\n*** or simply open an issue with the tag \"enhancement\".\n*** Don't forget to give the project a star!\n*** Thanks again! Now go create something AMAZING! :D\n--\u003e\n\n\n\n\u003c!-- PROJECT SHIELDS --\u003e\n\u003c!--\n*** I'm using markdown \"reference style\" links for readability.\n*** Reference links are enclosed in brackets [ ] instead of parentheses ( ).\n*** See the bottom of this document for the declaration of the reference variables\n*** for contributors-url, forks-url, etc. This is an optional, concise syntax you may use.\n*** https://www.markdownguide.org/basic-syntax/#reference-style-links\n--\u003e\n[![Contributors][contributors-shield]][contributors-url]\n[![Forks][forks-shield]][forks-url]\n[![Stargazers][stars-shield]][stars-url]\n[![Issues][issues-shield]][issues-url]\n[![MIT][license-shield]][license-url]\n[![LinkedIn][linkedin-shield]][linkedin-url]\n\n\n\n\u003c!-- PROJECT LOGO --\u003e\n\u003cbr /\u003e\n\u003cdiv align=\"center\"\u003e\n  \u003ca href=\"https://github.com/juliankrzysiak/jeblore\"\u003e\n    \u003cimg src=\"public/jeb-og.jpg\" alt=\"Logo\" width=\"400\"\u003e\n  \u003c/a\u003e\n\n\u003ch3 align=\"center\"\u003ejeblore\u003c/h3\u003e\n\n  \u003cp align=\"center\"\u003e\n    A website for jeblore, a webcomic about living with Jeb and other creatures.\n    \u003cbr /\u003e\n    \u003ca href=\"https://github.com/juliankrzysiak/jeblore\"\u003e\u003cstrong\u003eExplore the docs »\u003c/strong\u003e\u003c/a\u003e\n    \u003cbr /\u003e\n    \u003cbr /\u003e\n    \u003ca href=\"https://jeblore.com\"\u003eView Demo\u003c/a\u003e\n    ·\n    \u003ca href=\"https://github.com/juliankrzysiak/jeblore/issues/new?labels=bug\u0026template=bug-report---.md\"\u003eReport Bug\u003c/a\u003e\n    ·\n    \u003ca href=\"https://github.com/juliankrzysiak/jeblore/issues/new?labels=enhancement\u0026template=feature-request---.md\"\u003eRequest Feature\u003c/a\u003e\n  \u003c/p\u003e\n\u003c/div\u003e\n\n\n\n\u003c!-- TABLE OF CONTENTS --\u003e\n\u003cdetails\u003e\n  \u003csummary\u003eTable of Contents\u003c/summary\u003e\n  \u003col\u003e\n    \u003cli\u003e\n      \u003ca href=\"#about-the-project\"\u003eAbout The Project\u003c/a\u003e\n      \u003cul\u003e\n        \u003cli\u003e\u003ca href=\"#built-with\"\u003eBuilt With\u003c/a\u003e\u003c/li\u003e\n        \u003cli\u003e\u003ca href=\"#features\"\u003eFeatures\u003c/a\u003e\u003c/li\u003e\n        \u003cli\u003e\u003ca href=\"#how-its-made\"\u003eHow It's Made\u003c/a\u003e\u003c/li\u003e\n        \u003cli\u003e\u003ca href=\"#learning-outcomes\"\u003eLearning Outcomes\u003c/a\u003e\u003c/li\u003e\n      \u003c/ul\u003e\n    \u003c/li\u003e\n    \u003cli\u003e\n      \u003ca href=\"#getting-started\"\u003eGetting Started\u003c/a\u003e\n      \u003cul\u003e\n        \u003cli\u003e\u003ca href=\"#prerequisites\"\u003ePrerequisites\u003c/a\u003e\u003c/li\u003e\n        \u003cli\u003e\u003ca href=\"#installation\"\u003eInstallation\u003c/a\u003e\u003c/li\u003e\n      \u003c/ul\u003e\n    \u003c/li\u003e\n    \u003cli\u003e\u003ca href=\"#usage\"\u003eUsage\u003c/a\u003e\u003c/li\u003e\n\u003c!--\u003cli\u003e\u003ca href=\"#roadmap\"\u003eRoadmap\u003c/a\u003e\u003c/li\u003e --\u003e\n    \u003cli\u003e\u003ca href=\"#contributing\"\u003eContributing\u003c/a\u003e\u003c/li\u003e\n    \u003cli\u003e\u003ca href=\"#license\"\u003eLicense\u003c/a\u003e\u003c/li\u003e\n    \u003cli\u003e\u003ca href=\"#contact\"\u003eContact\u003c/a\u003e\u003c/li\u003e\n    \u003cli\u003e\u003ca href=\"#acknowledgments\"\u003eAcknowledgments\u003c/a\u003e\u003c/li\u003e\n  \u003c/ol\u003e\n\u003c/details\u003e\n\n\n\n\u003c!-- ABOUT THE PROJECT --\u003e\n## About The Project\n\nDesktop Light             |  Mobile Dark\n-------------------------|-------------------------\n\u003cimg src=\"https://github.com/user-attachments/assets/d1b9cfe8-6dbd-41db-844e-c46dcf400ece\" alt=\"Desktop screenshot\"\u003e  |  \u003cimg src=\"https://github.com/user-attachments/assets/b37065a4-4f03-460d-8893-06505b2e645b\" alt=\"Mobile screenshot\"\u003e\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n### Built With\n\n\u003c!-- \n* [![Next][Next.js]][Next-url]\n* [![React][React.js]][React-url]\n* [![Svelte][Svelte.dev]][Svelte-url]\n--\u003e\n\n* [![Astro][Astro-shield]][Astro-url]\n* [![TypeScript][TypeScript-shield]][TypeScript-url]\n* [![Keystatic][Keystatic-shield]][Keystatic-url]\n\n ### Features\n* Performant static site for hosting webcomics\n* Git-based CMS to easily change data\n* Simple and accessible design\n* Cool theme picker\n\n### How It's Made\n  I made this website using a static site generator, Astro, because it is perfect for content-focused websites like this for increases performance and pleasant DX. The only JS used is for the theme picker.\n\n  I designed the webite to be simple, emulating the simple mind of Jeb, our eponymous main character.\n\n  And the simplicity of use and focus on accessibility also leads to better UX.\n\n  Kepping in this theme, I wanted the website to be easily updated, so I opted for a git-based CMS, which would just store the images in the repo. All the images are optimized during the build process.\n\n### Learning Outcomes\n\n| The Good                               | The Bad                                              | The Ugly |\n|----------------------------------------|------------------------------------------------------|----------|\n| Performance from SSG   | Too much time spent on what is the best CMS   |           |\n| Back to Vanilla CSS |     Did not have a good time with Decap CMS                     |          |\n|             Accessibility            |   URL issues in prod                                                     |          |\n|            Theme Picker          |                                                      |          |\n  \n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- GETTING STARTED --\u003e\n## Getting Started\n\nTo get a local copy up and running follow the steps.\n\n### Prerequisites\n\nThis is an example of how to list things you need to use the software and how to install them.\n* pnpm\n  ```sh\n  npm install -g pnpm\n  ```\n\n### Installation\n\n1. Clone the repo\n   ```sh\n   git clone https://github.com/juliankrzysiak/jeblore.git\n   ```\n2. Go to project directory\n   ```sh\n   cd jeblore\n   ```\n3. Install dependencies\n   ```sh\n   pnpm install\n   ```\n4. Start the server\n   ```sh\n   pnpm start\n   ```\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- USAGE EXAMPLES --\u003e\n## Usage\n\nYou can add new comics or other data by accessing the CMS in dev mode. Start up dev mode then append /keystatic to the home url, eg. `http://127.0.0.1:4321/`.\n\nThe default storage mode is local, but this can be [changed to github](https://keystatic.com/docs/github-mode) to allow for others with write permission to the repo to change data. \n\n```js\nexport default config({\n\tstorage: {\n\t\tkind: 'github',\n\t}\n})\n```\n\nFor an easier option for non-tecnical clients, one can change the [storage mode to cloud](https://keystatic.com/docs/cloud).\n\nYou can easily change the structure of the data by going to `keystatic.config.ts` and modifying what you would like. \n\nI am hosting this on Cloudflare Pages, so you can get rid of the adapter in `astro.config.mjs` if you hosted elsewhere.\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\u003c!-- ROADMAP \n## Roadmap\n\n- [ ] Feature 1\n- [ ] Feature 2\n- [ ] Feature 3\n    - [ ] Nested Feature\n\nSee the [open issues](https://github.com/juliankrzysiak/jeblore/issues) for a full list of proposed features (and known issues).\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n--\u003e\n\n\u003c!-- CONTRIBUTING --\u003e\n## Contributing\n\nContributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are **greatly appreciated**.\n\nIf you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag \"enhancement\".\nDon't forget to give the project a star! Thanks again!\n\n1. Fork the Project\n2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)\n3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)\n4. Push to the Branch (`git push origin feature/AmazingFeature`)\n5. Open a Pull Request\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n### Top contributors:\n\n\u003ca href=\"https://github.com/juliankrzysiak/jeblore/graphs/contributors\"\u003e\n  \u003cimg src=\"https://contrib.rocks/image?repo=juliankrzysiak/jeblore\" alt=\"contrib.rocks image\" /\u003e\n\u003c/a\u003e\n\n\u003c!-- LICENSE --\u003e\n## License\n\nDistributed under the MIT license EXCEPT for any images / assets. See `LICENSE.txt` for more information.\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- CONTACT --\u003e\n## Contact\n\nJulian Krzysiak - jkrzysiak13@gmail.com\n\nProject Link: [https://github.com/juliankrzysiak/jeblore](https://github.com/juliankrzysiak/jeblore)\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\n\u003c!-- ACKNOWLEDGMENTS --\u003e\n## Acknowledgments\n\n* [Favicon Generator](https://favicon.io/)\n* [Making the theme picker accessible](https://fossheim.io/writing/posts/accessible-theme-picker-html-css-js/)\n\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n\n\n\u003c!-- MARKDOWN LINKS \u0026 IMAGES --\u003e\n\u003c!-- https://www.markdownguide.org/basic-syntax/#reference-style-links --\u003e\n[contributors-shield]: https://img.shields.io/github/contributors/juliankrzysiak/jeblore.svg?style=for-the-badge\n[contributors-url]: https://github.com/juliankrzysiak/jeblore/graphs/contributors\n[forks-shield]: https://img.shields.io/github/forks/juliankrzysiak/jeblore.svg?style=for-the-badge\n[forks-url]: https://github.com/juliankrzysiak/jeblore/network/members\n[stars-shield]: https://img.shields.io/github/stars/juliankrzysiak/jeblore.svg?style=for-the-badge\n[stars-url]: https://github.com/juliankrzysiak/jeblore/stargazers\n[issues-shield]: https://img.shields.io/github/issues/juliankrzysiak/jeblore.svg?style=for-the-badge\n[issues-url]: https://github.com/juliankrzysiak/jeblore/issues\n[license-shield]: https://img.shields.io/github/license/juliankrzysiak/jeblore.svg?style=for-the-badge\n[license-url]: https://github.com/juliankrzysiak/jeblore/blob/main/LICENSE.txt\n[linkedin-shield]: https://img.shields.io/badge/-LinkedIn-black.svg?style=for-the-badge\u0026logo=linkedin\u0026colorB=555\n[linkedin-url]: https://linkedin.com/in/juliankrzysiak\n[product-screenshot]: public/jb-og.png\n[Next.js]: https://img.shields.io/badge/next.js-000000?style=for-the-badge\u0026logo=nextdotjs\u0026logoColor=white\n[Next-url]: https://nextjs.org/\n[React.js]: https://img.shields.io/badge/React-20232A?style=for-the-badge\u0026logo=react\u0026logoColor=61DAFB\n[React-url]: https://reactjs.org/\n[Svelte.dev]: https://img.shields.io/badge/Svelte-4A4A55?style=for-the-badge\u0026logo=svelte\u0026logoColor=FF3E00\n[Svelte-url]: https://svelte.dev/\n[Astro-shield]: https://img.shields.io/badge/Astro-000000?style=for-the-badge\u0026logo=astro\u0026logoColor=BC52EE\n[Astro-url]: https://astro.build/\n[TypeScript-shield]: https://img.shields.io/badge/TypeScript-3178c6?style=for-the-badge\u0026logo=typescript\u0026logoColor=ffffff\n[TypeScript-url]: https://www.typescriptlang.org/\n[Keystatic-shield]: https://img.shields.io/badge/Keystatic-ffffff?style=for-the-badge\u0026logo=keystone\u0026logoColor=000000\n[Keystatic-url]: https://keystatic.com/\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjuliankrzysiak%2Fjeblore","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fjuliankrzysiak%2Fjeblore","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjuliankrzysiak%2Fjeblore/lists"}