I've had the opportunity to enrol in OSD700 - Open Source Development Project at Seneca Polytechnic, where I'll be learning to maintain and ship open source software as part of a team. As a part of the course, I'll be blogging weekly about everything I work on.
This term, we're going to be maintaining two projects: Starchart and ChatCraft.
DevelopingSpace / starchart
A self-serve tool for managing custom domains and certificates
Starchart makes it easy for the Seneca developer community to create and manager their own custom subdomains and SSL certificates, without cost or having to provide personal information.
For information about running Starchart, see our deployment guide. For development information, see our contributing guide. For further technical background, planning, and initial designs, please see the wiki.
Introduction
The internet is evolving, and what used to be hard has become simple. For example, hosting your own website used to require knowledge of server administration, operating systems, networking, etc. Today, many developers host their personal and project websites without ever touching a remote server, opting for (free) cloud services like GitHub Pages, Vercel, Netlify, or AWS.
The internet's security model is also evolving. For example, browser vendors have embraced HTTPS everywhere. This is good for security, as it enables certificate-based encryption between clients and servers. However, as withβ¦
tarasglek / chatcraft.org
Developer-oriented ChatGPT clone
ChatCraft.org
Welcome to ChatCraft.org, your open-source web companion for coding with Large Language Models (LLMs). Designed with developers in mind, ChatCraft transforms the way you interact with GPT models, making it effortless to read, write, debug, and enhance your code.
Whether you're exploring new designs or learning about the latest technologies, ChatCraft is your go-to platform. With a user interface inspired by GitHub, and editable Markdown everywhere, you'll feel right at home from the get-go.
Features
We think ChatCraft is the best platform for learning, experimenting, and getting creative with code. Here's a few of the reasons why we think you'll agree:
π οΈ You're in Control: Customize all aspects of a chat. Use your own System Prompts, edit, delete, and retry AI messages with models from competing vendors in the same chat.
π Multiple AI Providers: ChatCraft supports both OpenAI and OpenRouter, giving you access to aβ¦
I'll talk about my experience setting these up, and what I plan to work on for this sprint.
Setting up the projects
I was able to get both projects up and running fairly easily following the documentation. Starchart is an old project and hasn't been maintained for about two years, so I got warnings for a bunch of out-of-date dependencies, but was still able to get the webapp running.
ChatCraft is much more actively maintained, so I didn't run into any trouble setting it up.
First Contributions
I submitted some issues / pull requests for both projects - some feature suggestions and some documentation updates.
Starchart
For Starchart, I noticed a few areas for improvement in the docs:
- The contributing docs don't mention
docker compose down
, so contributors unfamiliar with Docker Compose might end up leaving the Docker services on their machines.
Add `docker compose down` to contributing docs #771
The contributing docs don't mention docker compose down
, so contributors unfamiliar with Docker Compose might end up leaving the containers on their machines.
- The section on squashing and merging pull requests has some misleading info saying squashing helps prevent losing the commit history.
- I think we could write a Makefile to simplify the developer environment setup and teardown.
Simplify dev environment setup with a Makefile #770
I think we can simplify the dev environment setup using a Makefile so that a single command can run all the necessary scripts:
I made a pull request to fix some typos and the section on merging pull requests. Unfortunately, it looks like Starchart's CI workflow is broken, because Playwright fails to install the dependencies it needs to run end-to-end tests. I haven't been able replicate this error on my local machine - I assume it's because of differences between my environment and the GitHub Actions environment. I'll have to look into the CI workflow.
Fix typos and "Merging to main" section in CONTRIBUTING.md #768
Fixes #767.
Fixed some typos. Also:
This section says that squashing and merging pull requests helps prevent losing the commit history which is not true. I've streamlined the section to remove that part.
Until this is resolved I've decided to hold off on making pull requests for the other two issues.
ChatCraft
As for ChatCraft, the Getting Started section of it's README had what I understood to be slightly outdated instructions, instructing new users to select an AI provider and to enter an API Key. These are optional steps tucked away in the settings, a fact the instructions failed to mention (which confused me when trying it out the first time). I filed an issue to address this.
README "Getting Started" section improvements #776
The Getting Started section of the README talks about choosing an AI provider and entering an API key, but fails to mention where to find these settings and that these steps are optional:
We could either remove those steps for the sake of simplicity (since it is supposed to be "Getting Started"), or label them as optional and mention where users can find those options.
I also opened an issue for adding a setting which updates the app theme dynamically when the system theme changes, instead of reading the system theme on start and then requiring manual toggling.
Add "Use System Theme" setting #781
I'd like a setting that makes the app theme change dynamically when the system theme changes.
I think setting useSystemColorMode
to true if the setting is toggled on would work:
Maybe also hide/disable the theme toggle button when this is on?
Other Plans For This Sprint
In terms of other stuff for this sprint, I'm still working on one of my pull requests to Mattermost from a while ago - I received a review last week so I have some changes to make:
[MM-53650] Add disable emoticon rendering setting to webapp #29414
This pull request adds a user setting to the webapp to toggle rendering emoticons (:D
) as emojis (π).
The setting is added as a component in components/user_settings/display/render_emoticons_as_emoji/
which is imported in components/user_settings/display/user_settings_display.tsx
.
I've added a renderOnOffLabel()
function to user_settings_display.tsx
, lifted from components/user_settings/advanced/user_settings_advanced.tsx
to help render the new component.
The setting is stored as a user preference using the savePreferences()
action.
I've added constants for the preference to utils/constants.tsx
and webapp/channels/src/packages/mattermost-redux/src/constants/preferences.ts
.
To actually use the setting, I've modified components/post_markdown
to receive it's value as a prop, for which I've used getBool()
and added a default value to the config. post_markdown
passes this value down to Markdown
on the options
object, which then passes it down to utils/text_formatting.tsx
, which finally passes the value to emoticons.tsx
as a newly added parameter. emoticons.tsx
checks whether the value is true and if it is, it transforms the emoticons into emojis.
I've updated affected tests and created unit tests for the new component. I've also updated the English translation file.
- Navigate to User Settings.
- Go to the Display category.
- Find the section labelled "Auto-render emoticons as emoji" and click "Edit".
- Toggle the setting and click "Save".
- Emoticon rendering on messages sent by the current user and other users should be toggled client-side with the setting.
Fixes (partially) https://github.com/mattermost/mattermost/issues/26504 Jira https://mattermost.atlassian.net/browse/MM-53650
Note the issue and ticket describe adding this feature to the mobile app as well, which this PR does not.
Added a new user setting to toggle rendering emoticons (:D) as emojis (π)
Top comments (0)