aboutsummaryrefslogtreecommitdiffstats
path: root/src/styles/pages/partials/_article-wp-blocks.scss
blob: 86be062991cd1881e2e2299a4bbce33d5ecaea8b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
pre { line-height: 125%; }
td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
.highlight .hll { background-color: #ffffcc }
.highlight .c { color: #888888 } /* Comment */
.highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */
.highlight .k { color: #008800; font-weight: bold } /* Keyword */
.highlight .ch { color: #888888 } /* Comment.Hashbang */
.highlight .cm { color: #888888 } /* Comment.Multiline */
.highlight .cp { color: #cc0000; font-weight: bold } /* Comment.Preproc */
.highlight .cpf { color: #888888 } /* Comment.PreprocFile */
.highlight .c1 { color: #888888 } /* Comment.Single */
.highlight .cs { color: #cc0000; font-weight: bold; background-color: #fff0f0 } /* Comment.Special */
.highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */
.highlight .ge { font-style: italic } /* Generic.Emph */
.highlight .gr { color: #aa0000 } /* Generic.Error */
.highlight .gh { color: #333333 } /* Generic.Heading */
.highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */
.highlight .go { color: #888888 } /* Generic.Output */
.highlight .gp { color: #555555 } /* Generic.Prompt */
.highlight .gs { font-weight: bold } /* Generic.Strong */
.highlight .gu { color: #666666 } /* Generic.Subheading */
.highlight .gt { color: #aa0000 } /* Generic.Traceback */
.highlight .kc { color: #008800; font-weight: bold } /* Keyword.Constant */
.highlight .kd { color: #008800; font-weight: bold } /* Keyword.Declaration */
.highlight .kn { color: #008800; font-weight: bold } /* Keyword.Namespace */
.highlight .kp { color: #008800 } /* Keyword.Pseudo */
.highlight .kr { color: #008800; font-weight: bold } /* Keyword.Reserved */
.highlight .kt { color: #888888; font-weight: bold } /* Keyword.Type */
.highlight .m { color: #0000DD; font-weight: bold } /* Literal.Number */
.highlight .s { color: #dd2200; background-color: #fff0f0 } /* Literal.String */
.highlight .na { color: #336699 } /* Name.Attribute */
.highlight .nb { color: #003388 } /* Name.Builtin */
.highlight .nc { color: #bb0066; font-weight: bold } /* Name.Class */
.highlight .no { color: #003366; font-weight: bold } /* Name.Constant */
.highlight .nd { color: #555555 } /* Name.Decorator */
.highlight .ne { color: #bb0066; font-weight: bold } /* Name.Exception */
.highlight .nf { color: #0066bb; font-weight: bold } /* Name.Function */
.highlight .nl { color: #336699; font-style: italic } /* Name.Label */
.highlight .nn { color: #bb0066; font-weight: bold } /* Name.Namespace */
.highlight .py { color: #336699; font-weight: bold } /* Name.Property */
.highlight .nt { color: #bb0066; font-weight: bold } /* Name.Tag */
.highlight .nv { color: #336699 } /* Name.Variable */
.highlight .ow { color: #008800 } /* Operator.Word */
.highlight .w { color: #bbbbbb } /* Text.Whitespace */
.highlight .mb { color: #0000DD; font-weight: bold } /* Literal.Number.Bin */
.highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */
.highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */
.highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */
.highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */
.highlight .sa { color: #dd2200; background-
@use "@styles/abstracts/functions" as fun;
@use "@styles/abstracts/mixins" as mix;
@use "@styles/abstracts/placeholders";

@mixin styles {
  .wp-block-quote {
    margin: var(--spacing-sm) 0;
    padding: var(--spacing-sm);
    position: relative;
    border: fun.convert-px(1) solid var(--color-border-dark);
    border-left: fun.convert-px(5) solid var(--color-border-dark);
    box-shadow: fun.convert-px(1) fun.convert-px(1) fun.convert-px(1) 0
        var(--color-shadow),
      fun.convert-px(3) fun.convert-px(3) fun.convert-px(4) 0
        var(--color-shadow);
    font-style: italic;

    > *:last-child {
      margin: 0;
    }

    cite {
      color: var(--color-fg-light);
      font-size: var(--font-size-sm);
      font-style: normal;
      font-weight: 600;
    }
  }

  .wp-block-code,
  .wp-block-preformatted {
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--color-bg-secondary);
    border: fun.convert-px(1) solid var(--color-border-light);
    color: var(--color-fg);
  }

  .wp-block-columns {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--spacing-md);
    margin: var(--spacing-md) 0;

    @include mix.media("screen") {
      @include mix.dimensions("sm") {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    &.are-vertically-aligned-center {
      align-items: center;
    }
  }

  .wp-block-column {
    > *:first-child {
      margin-top: 0;
    }

    > *:last-child {
      margin-bottom: 0;
    }
  }

  .wp-block-image,
  .wp-block-video {
    padding: fun.convert-px(4);
    border: fun.convert-px(1) solid var(--color-border);
    box-shadow: fun.convert-px(1) fun.convert-px(1) fun.convert-px(1) 0
      var(--color-shadow);
  }

  .wp-block-image {
    display: flex;
    flex-flow: column;
    width: fit-content;
    margin: 0 auto;
    position: relative;
    text-align: center;

    img {
      margin: auto;
    }

    figcaption {
      margin-top: fun.convert-px(4);
      font-size: var(--font-size-sm);
    }
  }

  .wp-block-gallery {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--spacing-sm);

    .blocks-gallery-grid {
      @extend %reset-list;

      grid-column: 1 / -1;
      grid-row: 1 / -1;
      display: grid;
      grid-template-columns: minmax(0, 1fr);
      gap: var(--spacing-sm);
    }

    .blocks-gallery-item {
      figure {
        margin: 0;
      }

      a {
        display: block;
        box-shadow: 0 0 fun.convert-px(1) 0 var(--color-shadow),
          fun.convert-px(2) fun.convert-px(2) fun.convert-px(2) 0
            var(--color-shadow-light),
          fun.convert-px(3) fun.convert-px(3) fun.convert-px(6) 0
            var(--color-shadow-light);

        &:hover,
        &:focus {
          transform: scale(1.05);
          box-shadow: 0 0 fun.convert-px(1) 0 var(--color-shadow),
            fun.convert-px(3) fun.convert-px(3) fun.convert-px(2) 0
              var(--color-shadow-light),
            fun.convert-px(5) fun.convert-px(5) fun.convert-px(8) 0
              var(--color-shadow-light);
        }

        &:focus {
          outline: solid var(--color-primary-light);
        }

        &:active {
          transform: scale(0.95);
          box-shadow: 0 0 fun.convert-px(1) 0 var(--color-shadow),
            fun.convert-px(2) fun.convert-px(2) fun.convert-px(2) 0
              var(--color-shadow-light),
            0 0 0 0 var(--color-shadow-light);
          outline: none;
        }
      }
    }

    &.aligncenter {
      .blocks-gallery-grid {
        align-items: center;
      }
    }

    @for $i from 0 to 6 {
      &.columns-#{$i} {
        @include mix.media("screen") {
          @include mix.dimensions("xs") {
            grid-template-columns: repeat(2, minmax(0, 1fr));

            .blocks-gallery-grid {
              grid-template-columns: repeat(2, minmax(0, 1fr));
            }
          }

          @include mix.dimensions("sm") {
            grid-template-columns: repeat(#{$i}, minmax(0, 1fr));

            .blocks-gallery-grid {
              grid-template-columns: repeat(3, minmax(0, 1fr));
            }
          }
        }
      }
    }

    .wp-block-image img {
      height: 100%;
      object-fit: cover;
    }
  }
}