-
Notifications
You must be signed in to change notification settings - Fork 132
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
Flesh out the requirements of subsites #1307
Comments
Keep in mind that the outer site should be able to override things in the sub-site (without modifying it) as that is one of the desired conditions for better reuse. That way, the sub-site can be adapted and integrated into the outer site better. |
Hmm in that case, isn't the above behaviours actually desired? (share also meaning the root site overrides the sub site's configurations) |
I was thinking along the lines of:
when you build the root site, all pages in the sub site would use theme B, otherwise theme A. There might be some usage benefits in keeping subsites independent like such.
For this, I was thinking along the lines of |
Yes, it is desired; the subsite should stand alone. It should not need to access the outer site. In addition, the outer site should be able to override subsite as necessary. |
that has it's benefits as well. I'm personally fine with either behaviour, the current situation being easier to implement (no changes required) Would this be completely a non-issue then? I feel like there's still something missing / unclarified though #1263 (comment) - |
I think it is good to think it through and clarify which things are overridable and specify how to override them. So, this issue is timely. Also, we may have to decide the default behavior for each. For example, we can say the outer site titlePrefix overrides the inner site titlePrefix by default, and provide a way to let the inner site keep its own title prefix (?) -- or vice versa, whichever way we decide. In the case of CS2103, the se-book subsite is not directly plugged into the outer site. Rather, its content are integrated into the website via another layer of glue-code (in the se-book-adapted folder). I suspect this would be the situation most of the time i.e., the outer site will pick and choose what content to take from the inner site and where to put them. The outer site might not even want to reuse the structure of the inner site; rather, it will impose its own structure on the inner site's pages so that it integrates well with the outer site. |
We can provide both options as well. I think it's more intuitive to make it conventionally hierarchical - if a subsite's config leaves a field empty, we don't override the root site's config. The downside to this being that if you want to deploy the subsite independently, you'd have to maintain a separate set of configs (but that should be reasonable). Certain fields will be the exception to this rule. Example
This is a little tricky though. Say we have
and both the root site and subsite have the I suggest, if the above configuration was
Related to the layout behaviour suggested above is this -- Say we have a generic page blob in the site config applying a certain layout, but I want a certain page to have a different layout. I could either a. create a whole separate entry for that page in I suggest reversing the above priority as a breaking change somewhere down the line too. |
The usage scenario I have in mind is that the outer site simply picks and chooses which parts of the inner site to integrate into the outer site. That is, we don't think of the inner site as a separate site but just a folder containing more .md files. However, variables and nunjucks defined for the inner site should still work. Are you thinking along the same lines or are you thinking of a different direction? |
I'm thinking this, + layouts (subsite pages don't currently use subsite layouts but the root site's unlike variables) for a start
After that we could look at providing configuration overriding:
so in the case the subsite would have the sketchy theme, but would inherit the |
Subsites work under the philosophy of - "you can create separate sites, then include and use one in another, but the included site should behave as if it was never included" (correct me if i'm wrong)
Currently however, only the following behaviours comply:
{{baseUrl}}
resolves to subsites' root directoriesAll other things here don't comply (based on some white box inferencing) (except baseUrl which shouldn't comply): https://markbind.org/userGuide/siteJsonFile.html
share - meaning subsites' pages should not be able to access the root site's properties / layouts / etc., only it's own. (it should be built as if it was built standalone)
All of this should be able to be easily achieved by creating a
Project
abstraction of sorts, which holds multipleSite
s, although some refactors might have to be made before that.The text was updated successfully, but these errors were encountered: