Skip to content
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

Proposal: [Catalog Domain] Course About page, Index Page, and Course Catalog MFE conversion #375

Open
GlugovGrGlib opened this issue Jul 30, 2024 · 24 comments
Assignees

Comments

@GlugovGrGlib
Copy link
Member

GlugovGrGlib commented Jul 30, 2024

Abstract

This proposal aims to transition the Course About, Catalog, and Index pages of the Open edX platform from legacy architecture to MFE. Historically, catalog and about pages are provided supporting functionality to Open edX learning, which is clearly described in DDD bounded contexts, therefore no major works or new features were introduced to these pages for a long time. As other parts of the system are converted to MFE any further maintenance and customizations are growing in cost.
The goal is to address maintenance challenges, improve user experience, and increase the platform's competitiveness. By adopting MFE, we will enable easier integration of new features, improve performance, and increase retention rate.

Detailed Product Proposal

No response

Context & Background (in brief, if a Product Proposal is linked above)

Overview of Current Challenges with Legacy Architecture for Course About and Catalog pages.

Maintenance Complexity: Maintaining both legacy and MFE pages whithin the OeX is time-consuming and costly. As other interfaces has already transitioned to MFEs, this pages require legacy approach for customizations which should be maintained and supported separately from other solutions in OeX system. Clients often seek systems with lower maintenance costs.

Customization Difficulty: Course catalog and about pages are challenging to customize in the current system due to limitations of legacy code, and tech debt around those functionalities. Course creators cannot modify search filters/facets without additional development to these pages, leading clients that don’t want to invest into 3rd-party systems like Wordpress to opt for other LMSs that allow such customizations for the catalog.

Integration Limitations: The legacy architecture lacks necessary attributes for smooth service integration. New features like a video player or taxonomy are challenging to incorporate into legacy pages, and it requires maintaining separate solutions to integrate other core features into these pages.

Pluginization Issues: The legacy architecture prevents the creation of new frontend and backend plugin types for these pages, that are more distinct from comprehensive theming, and can be reused in the Open edX community.

Adaptability on Mobile App: Course About page on mobile apps is not adaptive due to hard usage of custom HTML and specific layout of the page. It is difficult for students using mobile app to find information they need about the course.

The customizations to these pages aren't straightforward, but not that uncommon. For example, Raccoon Gang has done many projects to customize these pages, including rewriting the Course Catalog and Course About pages to make them unique and meet specific business needs.

Scope & Approach (in brief, if a Product Proposal is linked above)

Beneficiaries of this enhancement include:

Educational Institutions: With a more advanced API layer to support an easier integration with other systems, reduced maintenance burdens, and improved overall platform performance for catalog pages, educational institutions can meet more effectively their students' needs.

Students: Improved UX and performance will enable students to quickly find the information they need about courses, enhance course search functionality, and facilitate easier discovery of courses they are interested in.

Open edX Community: Moving from legacy architecture to MFE is likely to attract more community contributions, leading to the development of new plugins for the Course About and Course Catalog pages. This will also unblock new developments in Catalog domain, enabling the development of new features at a lower cost.

Open edX partners and Operators: Decreased maintenance costs may improve user retention rates, making Open edX a more attractive option compared to other LMS systems. As the customization complexity is decreased, Open edX vendors and operators will be able to easily adjust Catalog and About pages to unique business needs for the clients. This will benefit Open edX partners by potentially increasing their client base.

The high-level scope includes

  • A new MFE application is created to host Catalog domain related user interfaces.
  • Refactoring API Layer in edx-platform to integrate with new MFE interfaces for Course Catalog, Index, and Course About pages.
  • Enhancements for the integration capabilities of Open edX
  • Addition and integration of new features into new MFE pages in Catalog domain

Approach

Based on Raccoon Gang experience and previous work around conversion of LMS and Studio pages to MFE, the standard approach can be taken, using existing API, components and solutions whenever possible to ease the initial migration.
To save on cost for initial implementation, the previous solutions developed by Raccoon Gang can be taken as the basis. However, some features for enterprise or ecommerce may be considered obsolete and should be integrated into the core solution using plugin functionality.

Value & Impact (in brief, if a Product Proposal is linked above)

We believe the transfer of Course Catalog and Course About pages to MFE can have the following effect:

Increase Adoption Rate for the Open edX System:

Maintenance Cost Reduction: Moving to MFE will decrease maintenance costs, influencing user decisions to select Open edX over other systems.

Pluginization: Users can develop, share, and add plugins to the Course About and Catalog pages, meeting their needs without significant investments in customizations or integration with third-party systems.

Improved Integration: Enhanced APIs layer will facilitate easier integration with other systems, such as external CRM and CMS.

Consistent Architecture: A unified MFE architecture will streamline maintenance and customization efforts in the community.

Enhance User Experience:

Mobile Responsiveness: The Course About page will be more mobile-friendly, providing a better experience for students accessing the platform from the mobile app.

Improved Search Functionality: Enhanced search features will support students in quickly finding the courses they need. Integration of new search features developed for learning and course authoring MFEs might be much easier.

Support Development of Mobile Initiatives:

Adaptive Design: The division of fields in the Course About page enables the creation of a mobile-responsive design that improves student understanding and engagement.

Performance Improvements:

Performance: The load on the Course Catalog and Course About pages will decrease, enhancing overall platform performance. MFE solution will allow us to switch between different pages without full-page reload, which significantly enhances UX for end-users.

Advanced Caching: Use of the cache techniques for API responses on the frontend for the anonymous users.

Milestones and/or Epics

Milestone 1: Legacy to MFE & Pluginization Enablement

  • A new MFE application is created to host Catalog domain related user interfaces.
  • Refactoring API Layer in edx-platform to integrate with new MFE interfaces for Course Catalog, Index, and Course About pages.
  • Index page reimplementation as MFE.
  • Redesign Course Catalog page using Paragon Design System, and achieve feature parity with the legacy Course Catalog page in MFE.
  • Reimplement Course About page in MFE, by preserving the core functionality.
  • Enable frontend pluginization on Course About, Course Catalog, and Index pages, to meet user needs without extensive customizations.
  • Allow Operators to opt out of these pages in favor of third-party CMS integration

Milestone 2: Functional Enhancements

  • Improve API functionality for native catalog and 3rd party integration.
  • Enhance search capabilities, by utilizing new search, taxonomies and course attributes features.
  • Redesign Course About page, by dividing Course Overview HTML into several fields for better indexing and mobile adaptability. More information in the draft proposal - Improved enrolment views and mobile discovery

Futher development

  • WYSIWYG for course about page

Named Release

Teak

Timeline

Milestone 1

Autumn 2024 — Winter 2024

Milestone 2 and further customizations

Winter 2025 — Spring 2025 by Teak release.

Proposed By

Raccoon Gang

Additional Info

No response

Copy link

Thanks for your submission, @openedx/openedx-product-managers will review shortly.

@GlugovGrGlib GlugovGrGlib changed the title Course About page, Index Page, and Course Catalog MFE conversion Proposal: [Catalog Domain] Course About page, Index Page, and Course Catalog MFE conversion Jul 30, 2024
@jmakowski1123 jmakowski1123 moved this to [Prod Proposals] In Review in Open edX Roadmap Jul 30, 2024
@sarina
Copy link
Contributor

sarina commented Sep 24, 2024

Hi @GlugovGrGlib - I volunteered to coordinate this as I'm interested in it. However I'm not sure who the biggest stakeholders are, as I believe many sites use their own catalog functionality. Any thoughts?

@jmakowski1123
Copy link

Just noting that this proposal carries contingencies for mobile.

@marcotuts
Copy link

This work is a precursor to improved course / enrollment / discovery views for Mobile as well as improved authoring for enrollment pages out of the box for Open edX (web + mobile). Additional details are here: #369

I think a few providers who have spent cycles improving / modifying course discovery views would be able to provide input here on the value of MFE conversion. I can reach out to a few and ask for input.

@felipemontoya
Copy link
Member

I agree that bringing the "external" pages up to standard is necessary next step. Also I am all pro the pluginization and the inclusion of extensibility cases from the ground up. I believe we should have a very simple implementation of the course search/course about pages and leave every single extra feature to be build in plugins.

I don't think that we should strive for feature parity here as much as in other MFE conversions. These APIs and UIs have received no upgrades in a long time and we could take this opportunity to turn them in a better foundation for the extensibility case. Such as the replacement for the catalog service (course discovery) outlinined in course-discovery/issues/4449.

@GlugovGrGlib
Copy link
Member Author

@sarina That's great! I also believe providers have significant exposure to various catalog customization requests and could provide valuable input.
Based on our experience and initial research, most Open edX installations either rely on the default catalog functionality or have made attempts to customize it—especially within educational institutions. Only the largest, commercially focused installations tend to use external CMS/e-commerce integrations for their catalogs.

@felipemontoya I completely agree, that's the right approach.

@OmarIthawi
Copy link
Member

Thanks for the proposal.

I've been out of the loop for a while when it comes to DEPR and MFEs.

I see that SEO isn't mentioned here, which unlike other MFEs is important for the Course Catalog.

If we'd like to keep the platform lightweight and works out of the box, I think our standard Micro-frontend stack isn't useful and we need to think about the SEO and marketing experience in this specific MFE.

@sarina
Copy link
Contributor

sarina commented Oct 24, 2024

Apologies for the late review here. I agree with @felipemontoya

I believe we should have a very simple implementation of the course search/course about pages and leave every single extra feature to be build in plugins.

and would propose a milestone 0 that is the design of the new APIs and the MFE pages (with plugin slots specified, and mocks). That would end up being an extension of this product proposal for the community to review.

@OmarIthawi I'm not sure how to address SEO concerns. A part of me feels that an instance focused on SEO should potentially use a 3rd party CMS to focus on SEO needs, and by making clear and easy to use APIs we make it easier to leverage a 3rd party CMS.

@sarina
Copy link
Contributor

sarina commented Oct 24, 2024

@marcotuts @felipemontoya would you be able to review this plan? I think if accepted, we move on to a milestone 0 which itself will have another review/comment period of the technical specs and visual mocks.

@OmarIthawi
Copy link
Member

@OmarIthawi I'm not sure how to address SEO concerns. A part of me feels that an instance focused on SEO should potentially use a 3rd party CMS to focus on SEO needs, and by making clear and easy to use APIs we make it easier to leverage a 3rd party CMS.

My concern is that we're making Open edX more costly to adopt for small instances with limited budgets by removing basic public pages from the core of Open edX into an MFE.

@sarina Last time I checked, using pure React.js app isn't good for the SEO and harm crawling. So to put the home page as a pure JavaScript/React.js app without pre-rendering can be hamful to the most basic SEO and hurts Open edX adoption.

If we're going the MFE route and making edx-platform as a backend-only, I'd recommend investing in a Next.js app which is a bit more friendly for SEO as well as the added benefit of caching and providing pre-rendered pages for non-authenticated users. It doesn't have to be Next.js, WordPress/Drupal can be a good replacement as well.

I know this is a change from our MFE stack, so perhaps we should make this specific MFE replaceable as much as possible similar to how wer'e investing in making ecommerce replaceable via WooCommerce plugin.

@sarina
Copy link
Contributor

sarina commented Nov 5, 2024

@GlugovGrGlib could you please weigh in on Omar's above comment?

@pdpinch
Copy link

pdpinch commented Nov 5, 2024

Google's crawler has been parsing JavaScript for some time so using react.js, by itself, isn't a blocker for Google SEO.

But, you may want to consider social media. In my experience, Twitter, Slack, etc. don't go to the same effort to process JavaScript when you share URLs. It may be worth some effort to be sure that distinct about page URLs present distinct metadata and text when they are shared.

@OmarIthawi
Copy link
Member

Google's crawler has been parsing JavaScript for some time so using react.js, by itself, isn't a blocker for Google SEO.

Yes, thanks @pdpinch for pointing that out.

But, you may want to consider social media. In my experience, Twitter, Slack, etc. don't go to the same effort to process JavaScript when you share URLs. It may be worth some effort to be sure that distinct about page URLs present distinct metadata and text when they are shared.

Yup, that's the issue. I think we probably need to invest in a server-side rendered solution, unless we expect every installation to re-implement their own solution.

Popular solutions are: Next.js, WordPress, Drupal, Django app (server side rendering), and static page generators like GitHub pages Jeykll. Anything but a pure MFE in my opinion would work.

@cmltaWt0
Copy link

@OmarIthawi @pdpinch

Thank you for your feedback! It’s truly appreciated.

The pages mentioned in the proposal indeed hold significant SEO value, and I completely agree on the importance of carefully considering the technology we choose to implement.
I’ve asked the team to investigate potential solutions internally that align with the goal of being SEO-compliant while also transitioning away from the Legacy UI.

Additionally, we plan to create a discussion post to engage the community and address the technical challenges involved in this process.

@arbrandes @bradenmacdonald FYI

@crathbun428
Copy link

@sarina - this proposal came up during the Core Product Working group Meeting today. Jenna had mentioned that this work is needed to move forward with the MFE conversion project, but recognizes the concerns raised around SEO-compliance. She had suggested approving the proposal from a product side, while making sure the proposer does their due diligence around SEO-compliance in fleshing out their technical approach.

cc: @cmltaWt0, @jmakowski1123

@OmarIthawi
Copy link
Member

Thanks a lot @cmltaWt0!! Let me know if you need anything else :)

@sarina
Copy link
Contributor

sarina commented Dec 17, 2024

I'm fine approving it if everyone else is in agreement on the approach.

@sarina
Copy link
Contributor

sarina commented Dec 18, 2024

@cmltaWt0 - I suggest you follow up with Edly about SEO (perhaps Faqir could help find you someone - I can connect you two if you're not connected already). We'll mark this as approved from Product, with Engineering discovery needed to ensure that SEO capabilities are preserved in the conversion.

@sarina sarina moved this from [Prod Proposals] In Review to Backlog - Not resourced, can be picked up in Open edX Roadmap Dec 18, 2024
@OmarIthawi
Copy link
Member

@GlugovGrGlib @sarina @cmltaWt0 thanks for pushing this forward.

I think it's helpful to divide the SEO discussion into two parts:

SEO Downgrade compated to Mako

  • How this proposal downgrades SEO compared to existing Mako templates?
    • It uses client-side rendered content, which many bots, crawlers and search engines don't support.
    • It breaks Twitter, LinkedIn and other social share.
    • It, presumably, hurts load time.

In my opinion, this is an essential feature that we shouldn't downgrade from.

Additional SEO Features

  • How this proposal can improve SEO compated to existing Mako templates?
    • It could support custom tags, titles, meta data for SEO.
    • It could support Open Graph or other advanced SEO features.
    • Support for marketing tools, pixels, hubspot and other tools marketers uses

I'm sure many operators would appreciate such features, because many of those features are actually implemented in well maintained Open edX installations.

However, this is an upgrade from the existing status quo and it could be very well out of scope.

The SEO is an umbrella for many other tools and processes that we can't cover in the core platform easily. I hope it's now clearer what I meant by SEO.

@cmltaWt0
Copy link

@sarina Thank you! I’ve reached out to Faqir and involved @PKulkoRaccoonGang to investigate the topic further.

@PKulkoRaccoonGang
Copy link

Yup, that's the issue. I think we probably need to invest in a server-side rendered solution, unless we expect every installation to re-implement their own solution.

Popular solutions are: Next.js, WordPress, Drupal, Django app (server side rendering), and static page generators like GitHub pages Jeykll. Anything but a pure MFE in my opinion would work.

@OmarIthawi It also seems to me that it is not possible to achieve the SEO optimization that we have thanks to Legacy Mako templates with the current MFE stack. We can verify this by looking at the main page https://www.edx.org which is perfectly indexed by search engines and is integrated into various social networks (Twitter, Facebook, etc.), but does not use the MFE stack.

Screenshot 2024-12-27 at 13 47 44

This page uses a variety of tools, including useful marketing tools and Next.js.
Next.js is not inherently part of the current MFE stack, which raises several integration concerns:
Plugins and Configurations, Frontend Slots etc.

Additional SEO Features

  • How this proposal can improve SEO compated to existing Mako templates?
  • It could support custom tags, titles, meta data for SEO.
  • It could support Open Graph or other advanced SEO features.
  • Support for marketing tools, pixels, hubspot and other tools marketers uses

With the current MFE stack we can achieve some SEO optimization using React Helmet, sitemap.js and Open Graph meta tags. But this result will be inferior to the SSR (Next.js) approach.
Perhaps the technical implementation of the main page https://www.edx.org/ is a good example of implementation that will suit us.

@OmarIthawi
Copy link
Member

Perhaps the technical implementation of the main page https://www.edx.org/ is a good example of implementation that will suit us.

www.edx.org isn't edx-platform not an MFE. It's a sepearate site built probably on WordPress or Drupal. It uses (last time I checked) the MARKETING_SITE feature to integrate with the edx-platform.

A good example is probably https://srei.futurex.sa/, this is a site that uses the default Mako templates.

With the current MFE stack we can achieve some SEO optimization using React Helmet, sitemap.js and Open Graph meta tags. But this result will be inferior to the SSR (Next.js) approach.

Inferior is probably good, which preferable to no SEO at all. Having better SEO should not be the goal in my opinion. Base-line static site SEO is, in my opinion, all what small instances needs.

Think of someone with a very low budget and a free server credit looking to use Open edX for their learning initiative. Baseline SEO is important, top-line SEO isn't needed at all. Big platforms don't need this as they typically have engineers who can deploy all the SEO and other features they neeed.

@bradenmacdonald
Copy link

A good example is probably https://srei.futurex.sa/, this is a site that uses the default Mako templates.

If you visit https://srei.futurex.sa/courses with JavaScript disabled, you will see this page has exactly the same problem - no SSR of the course listing, so even though it's using Mako it has most of the problems you are mentioning. The list of courses requires JavaScript to load, just like it would in an MFE.

Course pages like https://srei.futurex.sa/courses/course-v1:rega+MAR101+MAR101_2023/about look pretty nice but this instance has obviously invested in creating a nice theme. Most Open edX operators get something more like this out of the box: https://open.uit.no/courses/course-v1:UiT+Reformasjonen+500_aar/about and I don't think it looks very good nor it is really "SEO-optimized" in any way (though it does load without JS).

When I post it on Twitter/X, there is no preview at all:

Screenshot


So: the existing pages have only moderate "SEO" and "social" compatibility at best, don't look very good, are difficult to customize, are not mobile friendly, and nobody ever works on improving them for various reasons - in part because big instances bypass them entirely.

The proposed MFE-based about/course-catalog pages would be an improvement in almost every way, with the exception that the course "about" pages in particular would have worse SEO for search engines and social media sites that don't support JavaScript/MFEs. As already mentioned, all the major search engines do support MFEs. So personally I don't think this is a reason to block the proposal.

Q: what do people think about NOT creating a new MFE for this proposal, but instead providing an out-of-the-box template for setting up a nice looking marketing site that uses Strapi or Wordpress, integrated with the new lightweight catalog API? There's need to reinvent the wheel, and this could be the "recommended" way to set up a marketing site. Plus everyone wants to have other pages on the site that they can edit, and we don't need to build a whole CMS here.

But if we don't go with that approach, then for the reasons I mentioned already, I do personally think this proposal should go ahead, designing a new "course listing" and "course about" page proposal in tandem with the work on replacing discovery service with the new lightweight catalog service.

  • I would hate to see the new MFE based on the existing discovery service API, which would be a waste of effort, need to be later redone, and wouldn't help small instances anyways
  • Rant: I also think we need to make the course outlines visible by default. Personally I think it's incredibly frustrating that you can't see the course outline/syllabus without enrolling in the course, even if it's a free course!
  • To address the SEO concerns, we should also look into improving our frontend-platform to support SEO/SSR, or convert it to use Next.js, Remix, or Vite so we have SSR as an option. I don't personally see this is as a big blocker for now, as mentioned.

@OmarIthawi
Copy link
Member

Thanks @bradenmacdonald for conducting the testing.

Apparently the situation of the default Open edX LMS is worse than I thought. On the positive side, this sets a very low bar for us to achieve.

To address the SEO concerns, we should also look into improving our frontend-platform to support SEO/SSR, or convert it to use Next.js, Remix, or Vite so we have SSR as an option. I don't personally see this is as a big blocker for now, as mentioned.

👍🏼

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: Backlog - Not resourced, can be picked up
Development

No branches or pull requests