@faststore/ui 2.0.114-alpha.0 → 2.0.117-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@faststore/ui",
3
- "version": "2.0.114-alpha.0",
3
+ "version": "2.0.117-alpha.0",
4
4
  "description": "A lightweight, framework agnostic component library for React",
5
5
  "author": "emersonlaurentino",
6
6
  "license": "MIT",
@@ -58,5 +58,5 @@
58
58
  "node": "16.18.0",
59
59
  "yarn": "1.19.1"
60
60
  },
61
- "gitHead": "3d49923a96682db78955fcf81e6f134161de0d40"
61
+ "gitHead": "0d97039ebb2acb1c000ca9a4c914c2388a4cd49e"
62
62
  }
@@ -0,0 +1,93 @@
1
+ [data-fs-navbar-links] {
2
+ // --------------------------------------------------------
3
+ // Design Tokens for Navbar Links
4
+ // --------------------------------------------------------
5
+
6
+ --fs-navbar-links-padding-top-notebook : var(--fs-spacing-1);
7
+ --fs-navbar-links-padding-bottom-notebook : var(--fs-navbar-links-padding-top-notebook);
8
+
9
+ --fs-navbar-links-bkg-color : var(--fs-color-body-bkg);
10
+
11
+ --fs-navbar-links-transition-property : var(--fs-transition-property);
12
+ --fs-navbar-links-transition-timing : var(--fs-transition-timing);
13
+ --fs-navbar-links-transition-function : var(--fs-transition-function);
14
+
15
+ --fs-navbar-links-border-top-width-mobile : var(--fs-border-width);
16
+ --fs-navbar-links-border-top-color-mobile : var(--fs-border-color-light);
17
+ --fs-navbar-links-border-bottom-width-mobile : var(--fs-navbar-links-border-top-width-mobile);
18
+ --fs-navbar-links-border-bottom-color-mobile : var(--fs-navbar-links-border-top-color-mobile);
19
+
20
+ // Link
21
+ --fs-navbar-links-link-width-notebook : auto;
22
+ --fs-navbar-links-link-padding-notebook : 0 var(--fs-spacing-0);
23
+
24
+ // List
25
+ --fs-navbar-links-list-padding-left-notebook : var(--fs-spacing-3);
26
+ --fs-navbar-links-list-margin-left-notebook : var(--fs-spacing-2);
27
+ --fs-navbar-links-list-border-left-width-notebook : var(--fs-border-width);
28
+ --fs-navbar-links-list-border-left-color-notebook : var(--fs-border-color-light);
29
+
30
+ // --------------------------------------------------------
31
+ // Structural Styles
32
+ // --------------------------------------------------------
33
+
34
+ position: relative;
35
+ background-color: var(--fs-navbar-links-bkg-color);
36
+ transition: var(--fs-navbar-links-transition-property) var(--fs-navbar-links-transition-timing) var(--fs-navbar-links-transition-function);
37
+
38
+ @include media("<notebook") { padding: 0; }
39
+
40
+ @include media(">=notebook") {
41
+ z-index: var(--fs-z-index-below);
42
+
43
+ > div {
44
+ display: flex;
45
+ align-items: center;
46
+ }
47
+ }
48
+
49
+ [data-fs-navbar-links-list] {
50
+ display: block;
51
+ }
52
+
53
+ [data-fs-navbar-links-list-item] {
54
+ display: flex;
55
+ align-items: center;
56
+ }
57
+
58
+ [data-fs-button] {
59
+ margin-left: calc(-1 * var(--fs-spacing-1));
60
+
61
+ // TODO: remove this after navbar 2.0 is implemented
62
+ &[data-fs-button-variant="tertiary"] {
63
+ color: var(--fs-color-text-display);
64
+ }
65
+
66
+ @include media("<notebook") {
67
+ display: none;
68
+ }
69
+ }
70
+
71
+ @include media(">=notebook") {
72
+ padding-top: var(--fs-navbar-links-padding-top-notebook);
73
+ padding-bottom: var(--fs-navbar-links-padding-bottom-notebook);
74
+
75
+ [data-fs-navbar-links-list] {
76
+ display: flex;
77
+ column-gap: var(--fs-spacing-3);
78
+ padding-left: var(--fs-navbar-links-list-padding-left-notebook);
79
+ margin-left: var(--fs-navbar-links-list-margin-left-notebook);
80
+ border-left: var(--fs-navbar-links-list-border-left-width-notebook) solid var(--fs-navbar-links-list-border-left-color-notebook);
81
+ }
82
+
83
+ [data-fs-navbar-links-list-item] {
84
+ width: var(--fs-navbar-links-link-width-notebook);
85
+ padding: var(--fs-navbar-links-link-padding-notebook);
86
+ }
87
+ }
88
+
89
+ @include media("<notebook") {
90
+ border-top: var(--fs-navbar-links-border-top-width-mobile) solid var(--fs-navbar-links-border-top-color-mobile);
91
+ border-bottom: var(--fs-navbar-links-border-bottom-width-mobile) solid var(--fs-navbar-links-border-bottom-color-mobile);
92
+ }
93
+ }
@@ -0,0 +1,53 @@
1
+ [data-fs-navbar-slider] {
2
+ // --------------------------------------------------------
3
+ // Design Tokens for Navbar Slider
4
+ // --------------------------------------------------------
5
+
6
+ // Default properties
7
+ --fs-navbar-slider-padding : var(--fs-spacing-3);
8
+
9
+ // Header
10
+ --fs-navbar-slider-header-padding-bottom : var(--fs-spacing-2);
11
+ --fs-navbar-slider-header-button-margin-right : calc(-1 * var(--fs-spacing-1));
12
+
13
+ // Footer
14
+ --fs-navbar-slider-footer-padding-top : var(--fs-navbar-slider-header-padding-bottom);
15
+ --fs-navbar-slider-footer-margin-top : var(--fs-navbar-slider-header-padding-bottom);
16
+
17
+ // Logo
18
+ --fs-navbar-slider-logo-height : 2.375rem;
19
+ --fs-navbar-slider-logo-padding : 0;
20
+ --fs-navbar-slider-logo-margin-right : var(--fs-spacing-5);
21
+
22
+ // --------------------------------------------------------
23
+ // Structural Styles
24
+ // --------------------------------------------------------
25
+
26
+ padding: var(--fs-navbar-slider-padding);
27
+
28
+ [data-fs-navbar-slider-header] {
29
+ padding: 0;
30
+ padding-bottom: var(--fs-navbar-slider-header-padding-bottom);
31
+ }
32
+
33
+ [data-fs-navbar-slider-logo] {
34
+ height: var(--fs-navbar-slider-logo-height);
35
+ padding: var(--fs-navbar-slider-logo-padding);
36
+ margin-right: var(--fs-navbar-slider-logo-margin-right);
37
+
38
+ img {
39
+ width: 100%;
40
+ height: 100%;
41
+ }
42
+ }
43
+
44
+ [data-fs-navbar-slider-footer] {
45
+ padding-top: var(--fs-navbar-slider-footer-padding-top);
46
+ margin-top: var(--fs-navbar-slider-footer-margin-top);
47
+
48
+ [data-fs-button-signin-link] {
49
+ width: fit-content;
50
+ padding-left: 0;
51
+ }
52
+ }
53
+ }
@@ -0,0 +1,202 @@
1
+ [data-fs-navbar] {
2
+ // --------------------------------------------------------
3
+ // Design Tokens for Navbar
4
+ // --------------------------------------------------------
5
+
6
+ // Default properties
7
+
8
+ --fs-navbar-height-mobile : 3.5rem;
9
+
10
+ --fs-navbar-bkg-color : rgb(255 255 255 / 90%);
11
+
12
+ --fs-navbar-transition-timing : var(--fs-transition-timing);
13
+ --fs-navbar-transition-function : var(--fs-transition-function);
14
+
15
+ --fs-navbar-box-shadow : 0 var(--fs-spacing-0) var(--fs-spacing-3) rgb(0 0 0 / 5%);
16
+
17
+ // Header
18
+ --fs-navbar-header-padding : 0 var(--fs-spacing-0);
19
+
20
+ --fs-navbar-header-padding-top-notebook : var(--fs-spacing-1);
21
+ --fs-navbar-header-padding-bottom-notebook : var(--fs-navbar-header-padding-top-notebook);
22
+
23
+ // Search
24
+ --fs-navbar-search-button-icon-width-mobile : var(--fs-spacing-5);
25
+ --fs-navbar-search-button-icon-height-mobile : var(--fs-navbar-search-button-icon-width-mobile);
26
+
27
+ // Search Expanded
28
+ --fs-navbar-search-expanded-input-wrapper-margin-right : 0.625rem;
29
+ --fs-navbar-search-expanded-input-wrapper-margin-left : var(--fs-spacing-9);
30
+
31
+ --fs-navbar-search-expanded-input-width : calc(100% - var(--fs-spacing-7));
32
+
33
+ --fs-navbar-search-expanded-button-icon-margin-right : -4.063rem;
34
+
35
+ // Logo
36
+ --fs-navbar-logo-border-left-width : var(--fs-border-width);
37
+ --fs-navbar-logo-border-left-color : var(--fs-border-color-light);
38
+
39
+ // --------------------------------------------------------
40
+ // Structural Styles
41
+ // --------------------------------------------------------
42
+
43
+ position: sticky;
44
+ top: 0;
45
+ z-index: var(--fs-z-index-high);
46
+ display: flex;
47
+ flex-direction: column;
48
+ justify-content: center;
49
+ padding: 0;
50
+ box-shadow: var(--fs-navbar-box-shadow);
51
+ transition: top var(--fs-navbar-transition-timing) var(--fs-navbar-transition-function);
52
+
53
+ @include media("<notebook") {
54
+ height: var(--fs-navbar-height-mobile);
55
+ }
56
+
57
+ &[data-fs-navbar-scroll="down"] {
58
+ > nav {
59
+ top: calc(-1 * var(--fs-spacing-3));
60
+ height: 0;
61
+ padding: 0;
62
+ opacity: 0;
63
+ }
64
+ }
65
+
66
+ &[data-fs-navbar-scroll="up"] {
67
+ > nav {
68
+ top: 0;
69
+ opacity: 1;
70
+ }
71
+ }
72
+
73
+ [data-fs-search-input] {
74
+ flex: 1 0 100%;
75
+ order: 2;
76
+
77
+ @include media("<notebook") {
78
+ display: none;
79
+ }
80
+ }
81
+
82
+ [data-fs-navbar-row] {
83
+ display: flex;
84
+ flex-flow: row wrap;
85
+ align-items: center;
86
+ justify-content: space-between;
87
+ width: 100%;
88
+
89
+ @include media("<notebook") {
90
+ padding: 0;
91
+ }
92
+
93
+ @include media(">=notebook") {
94
+ display: grid;
95
+ grid-template-columns: 1fr minmax(auto, 37.5rem) 1fr;
96
+ }
97
+
98
+ [data-fs-navbar-button-menu] {
99
+ @include media(">=notebook") { display: none; }
100
+ }
101
+ }
102
+
103
+ [data-fs-navbar-buttons] {
104
+ display: flex;
105
+ align-items: center;
106
+ justify-content: flex-end;
107
+
108
+ [data-fs-button-signin-link] + [data-fs-cart-toggle] {
109
+ @include media(">=notebook") {
110
+ margin-left: var(--fs-spacing-3);
111
+ }
112
+ }
113
+
114
+ [data-fs-button-signin-link] {
115
+ display: none;
116
+ }
117
+
118
+ @include media(">=notebook") {
119
+ order: 2;
120
+
121
+ [data-fs-button-signin-link] {
122
+ display: inline-flex;
123
+ }
124
+ }
125
+
126
+ [data-fs-search-input] {
127
+ display: none;
128
+ transition: flex var(--fs-navbar-transition-timing) var(--fs-navbar-transition-function);
129
+
130
+ @include media("<notebook") {
131
+ display: flex;
132
+ flex: 0;
133
+ flex-direction: column;
134
+ order: 0;
135
+ width: min-content;
136
+
137
+ &[data-fs-search-input-dropdown-visible="false"] [data-fs-search-input-field-input] {
138
+ width: 0;
139
+ padding: 0;
140
+ border-width: 0;
141
+
142
+ &:hover, &:focus, &:focus-visible &:hover:focus-visible {
143
+ border-width: 0;
144
+ box-shadow: 0 0;
145
+ }
146
+ }
147
+
148
+ [data-fs-icon] {
149
+ margin-right: 0;
150
+ line-height: 0;
151
+
152
+ svg {
153
+ width: var(--fs-navbar-search-button-icon-width-mobile);
154
+ height: var(--fs-navbar-search-button-icon-height-mobile);
155
+ }
156
+ }
157
+ }
158
+ }
159
+
160
+ &[data-fs-navbar-search-expanded="true"] {
161
+ width: 100%;
162
+
163
+ [data-fs-search-input] {
164
+ flex: 1 1;
165
+ margin-right: var(--fs-navbar-search-expanded-input-wrapper-margin-right);
166
+ margin-left: var(--fs-navbar-search-expanded-input-wrapper-margin-left);
167
+
168
+ [data-fs-search-input-field] [data-fs-search-input-field-input] {
169
+ width: var(--fs-navbar-search-expanded-input-width);
170
+ padding: var(--fs-spacing-2);
171
+ }
172
+
173
+ [data-fs-icon] {
174
+ margin-right: 0;
175
+ }
176
+ }
177
+
178
+ [data-fs-icon-button="true"] {
179
+ margin-right: var(--fs-navbar-search-expanded-button-icon-margin-right);
180
+ transition: margin var(--fs-navbar-transition-timing) var(--fs-navbar-transition-function);
181
+ }
182
+ }
183
+ }
184
+
185
+ [data-fs-navbar-header] {
186
+ padding: var(--fs-navbar-header-padding);
187
+ overflow-x: clip;
188
+ background-color: var(--fs-navbar-bkg-color);
189
+ backdrop-filter: blur(10px);
190
+ }
191
+
192
+ [data-fs-navbar-logo] {
193
+ align-self: stretch;
194
+
195
+ @include media("<notebook") {
196
+ padding: var(--fs-spacing-1) 0 var(--fs-spacing-1) var(--fs-spacing-3);
197
+ margin-right: auto;
198
+ margin-left: var(--fs-spacing-0);
199
+ border-left: var(--fs-navbar-logo-border-left-width) solid var(--fs-navbar-logo-border-left-color);
200
+ }
201
+ }
202
+ }
@@ -28,6 +28,8 @@
28
28
  @import "../components/molecules/InputField/styles";
29
29
  @import "../components/molecules/LinkButton/styles";
30
30
  @import "../components/molecules/Modal/styles";
31
+ @import "../components/molecules/NavbarLinks/styles";
32
+ @import "../components/molecules/NavbarSlider/styles";
31
33
  @import "../components/molecules/OrderSummary/styles";
32
34
  @import "../components/molecules/ProductCard/styles";
33
35
  @import "../components/molecules/ProductTitle/styles";
@@ -56,6 +58,7 @@
56
58
  @import "../components/organisms/FilterSlider/styles";
57
59
  @import "../components/organisms/Hero/styles";
58
60
  @import "../components/organisms/ImageGallery/styles";
61
+ @import "../components/organisms/Navbar/styles";
59
62
  @import "../components/organisms/OutOfStock/styles";
60
63
  @import "../components/organisms/PaymentMethods/styles";
61
64
  @import "../components/organisms/PriceRange/styles";