Stack layout functions - iamgio/quarkdown GitHub Wiki

Stack functions are those, in the subcategory of layout functions, that arrange a group of elements according to certain layout rules. Examples are row, column, grid.

In order to understand which elements they must handle, they rely on the strict Markdown concept of block, an isolated chunk of the document such as a paragraph, a code block, a list, a quote, etc.

.row
  A

  B

  C

The following example has only one item, as both A, B and C are part of the same paragraph (due to lazy lines):

.row
  A
  B
  C

Images are stackable too, as long as they are in different paragraphs.

.row
  ![](img1.png)

  ![](img2.png)

Every kind of block is supported:

.row
  > This is
  > a quote

  ```java
  This is code
  ```

  - This is
  - a list

According to the CommonMark specification, the following example brings to the same result as the previous one. It's however encouraged to keep the code well readable by spacing blocks properly.

.row
  > This is
  > a quote
  ```java
  This is code
  ```
  - This is
  - a list

All the stack functions accept the following optional arguments:

  • alignment: main axis alignment (CSS' justify-content rule)
  • cross: cross axis alignment (CSS' align-items rule)
  • gap: space between items (e.g. 20px, 3cm, 1.5in)

grid also accepts a mandatory columns argument, which takes an integer value.

.grid columns:{2} alignment:{spacearound} gap:{1cm}
  A

  *B*

  **C**

  ***D***

Other elements can join too:

# Contacts

.row alignment:{spacearound}
  .center
    **Michael Scott**  
    Dunder Mifflin Paper Company, Inc.    
    [[email protected]](mailto:[email protected])

  .center
    **Forrest Gump**  
    Bubba Gump Shrimp Co.  
    [[email protected]](mailto:[email protected])

Stack layouts can be infinitely nested within each other:

.row cross:{center} gap:{1in}
  A

  .grid columns:{2}
    B

    C

    D

    E

  .column gap:{5mm}
    F
  
    .row
      G

      H