-
Notifications
You must be signed in to change notification settings - Fork 2
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Suggestion/improvement request - expose the frontend/ app.html , favicon and *.css files #15
Comments
That's a great suggestion. Yes I shall expose the ability for custom css. I can modularize different parts to give you the ability to customize your layout. I'll have to check how much customizability I should support but this helps also use custome css in markdown just like in obsidian. |
I gave this some thought and was wondering what level of customizability would you need. For eg. at the component level like file-tree, the rendered page, etc or fine grained customization ? I think there's a trade off in terms of complexity of enabling this feature. I think I can make this work by allowing custom css that can be attached during run-time to override specific classes or style settings for specific aspects of the design.. This would be feasible and would not cause too much overhead. Let me know if this is along the lines of what you were thinking or you need something even lower.. |
In my opinion you should make it really high level. And keep it simple for people with close to zero web development skills (me included). If you consider the target user as someone who essentially wants to be able to publish markdown notes (like an Obsidian vault), then I think for most people there's 2 main things:
|
So for the structure of the page, when you mean true/false setting in the env, are you talking about enabling/disabling that component entirely ? Or you want to make it toggleable like in Obsidian-webpage-export ? Making the sections toggleable is definitely easy to implement. So regarding theming, do you only want to change the colors ? I checked out the Obsidian minimal publish theme, and it basically only seems to be setting the colors of different elements. publish.css seems to be overriding predefined variables to set new colors. If this is sufficient then it's very feasible to add this feature. Does this make sense ? So here are the options.. option 1 is straightforward and can be done while 2 is more complex and would need time to analyze. Let me know what you think. |
Obsidian-webpage-export (which I tried and which is why I'm comparing against) allows users to completely disable components in the export settings. Personally, I am not sure if you need to go that far. I'm perfectly happy with just the ability to toggle (by which I mean have it present, but having the button to show or collapse) each of the components (like the current tag explorer). If you give me option to disable that component, I will, but otherwise I might simply start with it collapsed if I'm given the option. Likewise, if someone doesn't really use headings within their text, the ToC becomes useless. I would not go any further than this. Based on your comment about layout complexity, I don't think it's worth it to start allowing to move things around. tag explorer:
table of contents:
graph view (from the roadmap):
I think colours, font and maybe font size will be the 3 things that most people would be interested in. If you change these you can make any site look entirely different. Just going to link the obsidian publish theme docs for reference:
I think option 1 is the clear winner. Layout changes will introduce too much complexity. Optional bind mount in docker with a publish.css or theme.css where anything set would override the default ? This simplifies the deployment. |
Hi,
I just thought I'd suggest the following to allow light customisation:
Mapping the frontend/ folder, or partse thereof, to a volume so that the app.html, favicon and the .css can be modified.
This would allow for an easy way to do light customisation.
I know you've mentioned the ability to use and entirely different frontend, but that would be beyond my ability ( and also not something I'd want to spend time on ).
However, it would be cool to have the ability to do some very light customisation.
A previous project I used for basic .md websites ( https://github.com/dbohdan/caddy-markdown-site ) allowed modifying a few bits of the html template and changing the .css.
As far as I am aware, Obsidian Publish also allows users to change the look of their websites by changing a .css. So this would fit in with that.
Thanks!
The text was updated successfully, but these errors were encountered: