Skip to content

Latest commit

 

History

History
301 lines (199 loc) · 8.44 KB

SPECS.md

File metadata and controls

301 lines (199 loc) · 8.44 KB

WDX-180 | Technical Details & Specifications


JEKYLL

Jekyll | About the main website and GitHub Pages

Website: https://in-tech-gration.github.io/WDX-180/

The following files and folders are part of the Jekyll static site generator used by GitHub Pages to build our main website:

.
├── curriculum
├── README.md
├── _config.yml
├── _offline.yml
└── assets
    ├── WDX.Header.Alternative.jpg
    ├── WDX.Header.jpg
    ├── css
    └── jekyll
  • offline.yml is used to build a local GitHub Pages site, excluding some folders that are not needed for offline usage by the students

"By default, Jekyll doesn't build files or folders that:

are located in a folder called /node_modules or /vendor

start with _, ., or #

end with ~

are excluded by the exclude setting in your configuration file

If you want Jekyll to process any of these files, you can use the include setting in your configuration file. (_config.yml)

Jekyll | How to | Update & Compile the Home Page?

  • Run: sgen pages/README.yaml from the root directory.

Jekyll | How to | Change Website Styling (CSS)

Edit the following file:

  • assets/jekyll/css/style.scss

Jekyll | How to | Change Website Layout (HTML)

Edit the following files:

  • assets/jekyll/_layouts/default.html (Main HTML file)
  • assets/jekyll/_includes/ (Includes)

Edit Frontmatter:

---
layout: v2
---

Make sure that a file v2.html exists in: /assets/jekyll/_layouts/v2.html

Jekyll | How to | Include CSS & JS in a markdown file

Q: How do I load a CSS file in a particular markdown file?

A: You will need to add the CSS filenames in a Frontmatter property named load_css, for example:

---
load_css:
  - typography.css
  - libs/tagify.min.css
---

# Markdown content here...

The css files (e.g. typography.css and tagify.min.css from the example above) must be placed inside the assets/jekyll/css/ folder.

How to include JS:

A: You will need to include the JS filename in a Front matter property named load_script_js:

The JS files must be placed inside assets/jekyll/_includes/. If this is a JS library it must be placed inside assets/jekyll/_includes/libs/.

---
load_script_js: 
  - setup_faq.js
  - app.js
---

# Markdown content here...

The JS files must be placed in the assets/jekyll/_includes/ folder.

The code that injects both CSS and JS inside Jekyll-generated files can be found at the bottom of this template: assets/jekyll/_layouts/default.html

Jekyll | How to | Create markdown links that open in a new Tab

Markdown for GitHub Pages (Kramdown) supports links that open in a new Tab:

[Link](URL){:target="_blank"} 

You can create a VSCode snippet:

"WDX:Kramdown target _blank": {
  "prefix": "_blank",
  "body": [
    "{:target=\"_blank\"}"
  ],
  "description": "SGEN:Kramdown target _blank"
},

Jekyll | How to | Prevent build on GitHub Pages

Just include a .nojekyll file in the repo.

Jekyll | How to | Build Locally

source "https://rubygems.org"

gem 'github-pages', group: :jekyll_plugins
gem "webrick", "~> 1.8"

# gem 'github-pages'
# gem "jekyll-readme-index", "~> 0.3.0"
# gem "jekyll-theme-midnight", "= 0.2.0"
# gem "jekyll-sass-converter", "= 1.5.2"
  • Run:
    • bundle add webrick
    • bundle install
    • bundle exec jekyll _3.9.3_ serve
    • or npm run build:jekyll

REFERENCES:

Jekyll | How to | Add custom attributes to Markdown links

![](./assets/image.jpg){:style="width:100%"}

Jekyll | How to | Create interactive coding playground (inline)

Instructions: https://in-tech-gration.github.io/WDX-180/curriculum/features/flems/

Related Assets:

  • /assets/js/flems/flems_init.js
  • /assets/jekyll/css/style.scss (Check: // FLEMS CODE SECTIONS)
  • /assets/js/flems/flems.html

Jekyll | How to | Add Comments Widget (Utteranc.es)

Just add the following:

**Questions, comments, suggestions? Please leave them on the comment section below.**

<script src="https://utteranc.es/client.js"
  repo="in-tech-gration/WDX-180"
  issue-term="pathname"
  theme="github-dark"
  crossorigin="anonymous"
  async>
</script>

Jekyll | How to | Properly add Syntax Highlighting for JSX

  • Put code inside {% raw %} {% endraw %}

Jekyll | How to | Enable/Disable Animated Bubbles Effect?

How can I disabled the Animated Bubbles effect found on the FAQ page?

Remove the following line form the Frontmatter section:

  • animated.bubbles.js

How can I enable it on another page?

Add the following line to the Frontmatter section:

  • animated.bubbles.js

Jekyll | How to | Embed YouTube Videos?

(work in progress)

Jekyll | How to | Add a Header Image for each Week?

In the yaml file (e.g. week13.yaml) add a new YAML property named header_image: and add the full path. The sgen tool will automatically detect the image path and will copy the file to the appropriate weekly folder.

Jekyll | How to | Add a Quiz?

Take a look at the contents of curriculum/week01/exercises/Absolute_vs_Relative_URLs/index.md


About the Instructor's Cockpit Tool

This is a tool that helps instructors and mentors track their students' progress.

To launch the tool:

  • npm install inside the tools/instructor folder.
  • npm run cockpit

Tech Specs:

  • Express.js (backend)
  • JavaScript (frontend)

Configuration:

You first need to create one or more yaml files inside the teaching/cohorts/ folder which must contain a list of students. For a sample yaml file check /teaching/cohort.yaml.sample.

IMPORTANT: You should keep the /teaching/cohorts/ folder in .gitignore and never push it on GitHub.


About the npm run learn platform

This is a Next.js project bootstrapped with create-next-app.

The Next.js project (now) lives inside the npm-run-learn branch

The following files and folders are part of the Next.js Application:

├── NEXTJS.README.md
├── app/
├── components/
├── next-env.d.ts
├── next.config.js
├── package-lock.json
├── package.json
├── postcss.config.js
├── public/
├── tailwind.config.js
└── tsconfig.json

Getting Started

First, run the development server:

npm run dev
# or
yarn dev
# or
pnpm dev

Open http://localhost:3000 with your browser to see the result.

You can start editing the page by modifying app/page.tsx. The page auto-updates as you edit the file.

API routes can be accessed on http://localhost:3000/api/hello. This endpoint can be edited in pages/api/hello.ts.

The pages/api directory is mapped to /api/*. Files in this directory are treated as API routes instead of React pages.

This project uses next/font to automatically optimize and load Inter, a custom Google Font.

Learn More

To learn more about Next.js, take a look at the following resources:

You can check out the Next.js GitHub repository - your feedback and contributions are welcome!

About the template

Read https://cruip.com/docs/next-js-templates-tailwind-css/