aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/molecules/meta-list/meta-item/meta-item.module.scss
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2023-10-10 19:37:51 +0200
committerArmand Philippot <git@armandphilippot.com>2023-11-11 18:14:41 +0100
commitc87c615b5866b8a8f361eeb0764bfdea85740e90 (patch)
treec27bda05fd96bbe3154472e170ba1abd5f9ea499 /src/components/molecules/meta-list/meta-item/meta-item.module.scss
parent15522ec9146f6f1956620355c44dea2a6a75b67c (diff)
refactor(components): replace Meta component with MetaList
It removes items complexity by allowing consumers to use any label/value association. Translations should also be defined by the consumer. Each item can now be configured separately (borders, layout...).
Diffstat (limited to 'src/components/molecules/meta-list/meta-item/meta-item.module.scss')
-rw-r--r--src/components/molecules/meta-list/meta-item/meta-item.module.scss62
1 files changed, 62 insertions, 0 deletions
diff --git a/src/components/molecules/meta-list/meta-item/meta-item.module.scss b/src/components/molecules/meta-list/meta-item/meta-item.module.scss
new file mode 100644
index 0000000..a1c2d47
--- /dev/null
+++ b/src/components/molecules/meta-list/meta-item/meta-item.module.scss
@@ -0,0 +1,62 @@
+@use "../../../../styles/abstracts/functions" as fun;
+
+.item {
+ column-gap: var(--spacing-2xs);
+ align-content: baseline;
+
+ &--bordered-values {
+ row-gap: var(--spacing-2xs);
+ }
+
+ &--centered {
+ margin-inline: auto;
+ text-align: center;
+ place-items: center;
+ justify-content: center;
+ }
+
+ &--inlined {
+ align-items: first baseline;
+ }
+
+ &--inlined-values {
+ flex-flow: row wrap;
+ }
+
+ &:not(#{&}--bordered-values) {
+ row-gap: fun.convert-px(3);
+ }
+}
+
+.value {
+ width: fit-content;
+ height: fit-content;
+ color: var(--color-fg);
+ font-weight: 400;
+}
+
+:where(.item--bordered-values) {
+ .value {
+ padding: fun.convert-px(2) var(--spacing-2xs);
+ border: fun.convert-px(1) solid var(--color-primary-darker);
+ }
+}
+
+:where(.item--inlined-values) {
+ .label {
+ flex: 1 0 100%;
+ }
+}
+
+/* It's an arbitrary choice. When there is only one meta item (like on small
+ * cards) removing the width can mess up the layout. However, must of the times
+ * when there are multiples items, we need to remove the width especially if we
+ * want to use `isCentered` prop. */
+:where(.item--inlined-values:not(:only-of-type)) {
+ .label {
+ /* We need to remove its width to avoid an extra space and make the
+ * container width fit its contents. However the label should be smaller
+ * than the values to avoid unexpected behavior with layout. */
+ width: 0;
+ }
+}