Skip to content

Latest commit

 

History

History
183 lines (119 loc) · 10.1 KB

README.md

File metadata and controls

183 lines (119 loc) · 10.1 KB


Google Summer of Code 2023

FreeCAD

Table of Contents

About FreeCAD

  • FreeCAD is a general-purpose parametric 3D computer-aided design (CAD) modeler and a Building Information Modeling (BIM) software application with Finite-Element Method (FEM) support.
  • It is intended for mechanical engineering product design but also expands to a broader range of uses around engineering, such as architecture or electrical engineering.
  • FreeCAD is free and open-source, under the LGPL-2.0-or-later license, and available for Linux, macOS, and Windows operating systems.

Introduction

FreeCAD possesses a vast amount of documentation that is written by its users and hosted on the FreeCAD Wiki. The entire documentation is currently managed by MediaWiki software, which faces several problems and poses a potential threat.

  1. The MediaWiki software is massive and therefore, it becomes difficult and complicated to maintainup-to-date.
  2. The data published on MediaWiki is hard to backup, so there is a constant risk of losing data.
  3. The search feature supported by MediaWiki is extremely weak.

The FreeCAD documentation is as important as the software, and it would benefit from the same level of decentralization.

The aim was to rework the documentation system to a simple, file-based,versioned system that supports Git and Markdown for easy editing and version control, and offer FreeCAD users a good web-based experience with a robust search system.

Project Team

Work Summary

New documentation

A new documentation system is built using Docusaurus, which builds a single-page application with fast client-side navigation.

New documentation in light theme

Description

  • The documentation can now be viewed in both light and dark themes.

New documentation in dark theme

  • Release notes of the FreeCAD software can be viewed directly from the navbar, without needing to navigate.

Release notes dropdown menu

  • The option to switch to a different language is also provided in the navbar for convenience of the users.

Language switch dropdown menu

  • The features of the documentation can be extended and customized by React components.

For more information on the Docusaurus platform, check here.

Search infrastructure

The documentation system now uses Algolia DocSearch to search within the documentation.
Commit c78eb6d

Description

  • DocSearch is a free search infrastructure.
  • It is built on top of the latest version of Algolia Autocomplete, which provides better accessibility, increased responsiveness, themability, a better built-in design, and customizability under low-network conditions.
  • Credentials and API key to use the search feature was provided via email after applying to the DocSearch program.

More information on the DocSearch platform can be found here.

Offline documentation support

  • Users can also make a Developer's handbook or and offline copy of the documentation, in a PDF format, by running the command:
npx docs-to-pdf --initialDocURLs="https://freecad-documentation.netlify.app/docs/intro" --contentSelector="article" --paginationSelector="a.pagination-nav__link.pagination-nav__link--next" --excludeSelectors=".margin-vert--xl a,[class^='tocCollapsible'],.breadcrumbs,.theme-edit-this-page" --coverImage="https://upload.wikimedia.org/wikipedia/commons/thumb/f/f7/FreeCAD-logo.svg/96px-FreeCAD-logo.svg.png?20230430105342" --coverTitle="FreeCAD Documentation" --outputPDFFilename="freeCAD-documentation.pdf"

Cover page of the PDF format offline documentation

  • The PDF generated supports hyperlinks, and can be customized as per the user needs by the CLI options mentioned below.

Hyperlinks supported in offline documentation

CLI options for PDF generation

Option Required Description
--initialDocURLs Yes Set URL to start generating PDF from
--contentSelector Yes Used to find the part of main content
--paginationSelector Yes CSS Selector used to find the next page to be printed for looping
--excludeURLs No URLs to be excluded in PDF
--excludeSelectors No Exclude selectors from PDF. Separate each selector with a comma and no space. But you can use space in each selector.
ex: --excludeSelectors=".nav,.next > a"
--cssStyle No CSS style to adjust PDF output
ex: --cssStyle="body{padding-top: 0;}"
--outputPDFFilename No Name of the output PDF file
default is freeCAD-documentation.pdf
--pdfMargin No Set margin around PDF file.
separate each margin with comma and no space.
ex: --pdfMargin="10,20,30,40".
This sets margin top: 10px, right: 20px, bottom: 30px, left: 40px
--coverTitle No Title for the PDF cover
--coverSub No Subtitle the for PDF cover.
Add <br/> tags for multiple lines.
--filterKeyword No Only adds pages to the PDF containing a given meta keywords.
Makes it possible to generate PDFs of selected pages.

For more information on CLI options, refer to here.

Future Work

Even though there is an option for language support, the markdown files still need to be translated.
It is a work in progress, and the general idea of doing it is mentioned here.

  • The potential platforms for doing the translations are Crowdin and Transifex.
    Weblate was being considered earlier, but it has no markdown support, making it inviable.

  • Translations were being done using the Crowdin platform, but it only had a free trial period of 14 days.

  • The potential solution, which is now being worked upon, is to make an i18n folder with language subfolders in it and give a file-system structure like this.

Acknowledgments

I am thrilled that I had the opportunity to participate in the Google Summer of Code program this year.

I am deeply grateful to my mentors Kurt Kremitzki, Yorik van Havre, and Chris Hennes for giving me the opportunity to work on a project which is so significant to the FreeCAD software.
A special thanks to Kurt Kremitzki, who guided me patiently through the project and was always ready to help, review work in progress, and give feedback regarding the overall shape of the project and the feasibility of certain solutions. He devoted a lot of time to this project and led the video meetings in an organized, yet non-stressful manner.

I would also like to thank the FreeCAD community for their inputs, reviews, and suggestions on the project. Their support and positivity helped me throughout and made me enjoy every bit of it.

Last but not least, I sincerely appreciate Google and Google Summer of Code organizers for this amazing initiative.

References

Help, Feedback, and Contribute

Feel free to reach out to me to suggest changes, offer reviews, and discuss potential ideas for the project :)