Skip to content

Commit

Permalink
feat(mixins-logical-props): ✨ add margin-right mixin with its logic…
Browse files Browse the repository at this point in the history
…al-props
  • Loading branch information
krypton225 committed May 25, 2024
1 parent 5b0c794 commit 464d498
Show file tree
Hide file tree
Showing 2 changed files with 108 additions and 0 deletions.
5 changes: 5 additions & 0 deletions src/mixins/logical-props/_index.scss
Original file line number Diff line number Diff line change
Expand Up @@ -21,3 +21,8 @@
// * This module likely contains margin-bottom logical props.
// @see margin-bottom
@forward "./margin-bottom";

// * forwarding the "margin-right" module.
// * This module likely contains margin-right logical props.
// @see margin-right
@forward "./margin-right";
103 changes: 103 additions & 0 deletions src/mixins/logical-props/_margin-right.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,103 @@
@charset "UTF-8";

// @description
// * mr mixin.
// * This mixin generates CSS logical properties for margin-right.
// * It will generate margin-right & margin-inline-start properties.

// @access public

// @version 1.0.0

// @author Khaled Mohamed

// @license MIT

// @repository: https://github.com/ZexLabs/sass-pire

// @namespace logical-props

// @module logical-props/mr

// @dependencies:
// * - meta.type-of (SASS function).
// * - math.unit (SASS function).
// * - list.index (SASS function).
// * - Error.toggle (function).

// @example
// * .example {
// * @include mr(2rem);
// * }

// @output
// * .example {
// * margin-inline-start: 2rem;
// * margin-right: 2rem;
// * }

@use "sass:meta";
@use "sass:list";
@use "sass:math";
@use "../../development-utils/toggle-error-message" as Error;

@mixin mr($value: 0) {
@if meta.type-of($value) != number {
content: Error.toggle("The parameter of mr mixin must be in a number type.");
} @else {
$get-unit: math.unit($value);

@if $get-unit != "" {
$all-units: (
cm,
mm,
in,
px,
pt,
pc,
"%",
em,
ex,
ch,
rem,
vw,
vh,
vmin,
vmax,
dpi,
dpcm,
dppx,
vw,
svw,
lvw,
dvw,
vh,
lvh,
dvh,
vi,
svi,
lvi,
vmin,
svmin,
lvmin,
dvmin,
vmax,
svmax,
lvmax,
dvmax,
vb,
lvb,
dvb
) !default;

@if list.index($all-units, $get-unit) {
margin-inline-start: $value;
margin-right: $value;
} @else {
content: Error.toggle("The parameter of mr mixin must be one of these values: (#{$all-units}).");
}
} @else {
content: Error.toggle("The parameter of mr mixin must have a unit.");
}
}
}

0 comments on commit 464d498

Please sign in to comment.