T
T
Theory Theory2020-08-10 11:47:27
css
Theory Theory, 2020-08-10 11:47:27

Automatic @font-face generation with gulp?

There is a OpenSans-Regular.woff font in the fonts folder, how can I include it in fonts.scss in one click?? To avoid manually writing the @font-face construct?

Answer the question

In order to leave comments, you need to log in

1 answer(s)
F
FeST1Val, 2020-08-10
@Narbek

Use Mixin

@include font-face('Montserrat', '/app/fonts/Montserrat/Montserrat-Bold', bold, normal, woff2 woff ttf eot svg);

@function str-replace($string, $search, $replace: "") {
  $index: str-index($string, $search);

  @if $index {
    @return str-slice($string, 1, $index - 1) + $replace + str-replace(str-slice($string, $index + str-length($search)), $search, $replace);
  }

  @return $string;
}

@mixin font-face($name, $path, $weight: null, $style: null, $exts: eot woff2 woff ttf svg) {
  $src: null;

  $extmods: (
    eot: "?",
    svg: "#" + str-replace($name, " ", "_")
  );

  $formats: (
    otf: "opentype",
    ttf: "truetype"
  );

  @each $ext in $exts {
    $extmod: if(map-has-key($extmods, $ext), $ext + map-get($extmods, $ext), $ext);
    $format: if(map-has-key($formats, $ext), map-get($formats, $ext), $ext);
    $src: append($src, url(quote($path + "." + $extmod)) format(quote($format)), comma);
  }

  @font-face {
    font-family: quote($name);
    font-weight: $weight;
    font-style: $style;

    // font-display: block;
    src: $src;
  }
}

Didn't find what you were looking for?

Ask your question

Ask a Question

731 491 924 answers to any question