afront 1.0.12 → 1.0.15

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.
Files changed (61) hide show
  1. package/README.md +16 -1
  2. package/build-prod/favicon.ico +0 -0
  3. package/build-prod/index.html +1 -1
  4. package/build-prod/static/css/3-9c6342b57f1fdf7f0ec5.css +1 -0
  5. package/build-prod/static/css/41-22612c2a4de21ad2218c.css +1 -0
  6. package/build-prod/static/css/573-bb6eb6b1c144662d2253.css +1 -0
  7. package/build-prod/static/css/main-a08a4339cd89cae8b8b3.css +1 -0
  8. package/build-prod/static/js/3-985f8801e97b3b2025e2.js +1 -0
  9. package/build-prod/static/js/41-a66fae84fd39cfb1e349.js +1 -0
  10. package/build-prod/static/js/573-f7791eb491c75b0ccfb7.js +1 -0
  11. package/build-prod/static/js/main-588cd80aa8f9bdc45828.js +1 -0
  12. package/build-prod-ssr/3.ssr.prod.js +1 -1
  13. package/build-prod-ssr/41.ssr.prod.js +1 -1
  14. package/build-prod-ssr/573.ssr.prod.js +1 -1
  15. package/build-prod-ssr/ssr.prod.js +1 -1
  16. package/build-prod-ssr/static/css/3-9c6342b57f1fdf7f0ec5.css +1 -0
  17. package/build-prod-ssr/static/css/41-22612c2a4de21ad2218c.css +1 -0
  18. package/build-prod-ssr/static/css/573-bb6eb6b1c144662d2253.css +1 -0
  19. package/build-prod-ssr/static/css/main-a08a4339cd89cae8b8b3.css +1 -0
  20. package/build-prod-static/favicon.ico +0 -0
  21. package/build-prod-static/index.html +1 -1
  22. package/build-prod-static/static/css/23-22612c2a4de21ad2218c.css +1 -0
  23. package/build-prod-static/static/css/303-9c6342b57f1fdf7f0ec5.css +1 -0
  24. package/build-prod-static/static/css/636-bb6eb6b1c144662d2253.css +1 -0
  25. package/build-prod-static/static/css/main-a08a4339cd89cae8b8b3.css +1 -0
  26. package/build-prod-static/static/js/23-9e69ffb20f982ca1ba75.js +1 -0
  27. package/build-prod-static/static/js/303-1b6136e5efb4925c5f98.js +1 -0
  28. package/build-prod-static/static/js/636-7f7bf68f9765bc200b86.js +1 -0
  29. package/build-prod-static/static/js/main-1b27003ae778104f5ac2.js +1 -0
  30. package/install.js +1 -1
  31. package/package.json +7 -6
  32. package/src/Components/Header/Header.js +28 -30
  33. package/src/Pages/Home.js +30 -23
  34. package/src/Routes/ARoutes.js +1 -1
  35. package/src/Static/appStatic.js +1 -1
  36. package/src/Style/MeshGradient.module.css +1 -1
  37. package/src/Style/Style.module.css +34 -33
  38. package/src/index.js +2 -2
  39. package/webpack.build-prod.js +1 -2
  40. package/webpack.prod.js +1 -1
  41. package/webpack.ssr.prod.js +1 -1
  42. package/build-prod/static/css/3-9b9bcf0b9b877caf80c6.css +0 -1
  43. package/build-prod/static/css/41-1bd05b5a5a70ee2fc084.css +0 -1
  44. package/build-prod/static/css/573-7b8794ea227293d474c9.css +0 -1
  45. package/build-prod/static/css/main-5aff2d8a2fc28d01fdad.css +0 -1
  46. package/build-prod/static/js/3-cde9f071488e7a433907.js +0 -1
  47. package/build-prod/static/js/41-e973a17863e1084774d7.js +0 -1
  48. package/build-prod/static/js/573-21fb9ccdf567d99f4539.js +0 -1
  49. package/build-prod/static/js/main-cc87f2505014acdf4863.js +0 -1
  50. package/build-prod-ssr/static/css/3-9b9bcf0b9b877caf80c6.css +0 -1
  51. package/build-prod-ssr/static/css/41-1bd05b5a5a70ee2fc084.css +0 -1
  52. package/build-prod-ssr/static/css/573-7b8794ea227293d474c9.css +0 -1
  53. package/build-prod-ssr/static/css/main-5aff2d8a2fc28d01fdad.css +0 -1
  54. package/build-prod-static/static/css/23-1bd05b5a5a70ee2fc084.css +0 -1
  55. package/build-prod-static/static/css/303-9b9bcf0b9b877caf80c6.css +0 -1
  56. package/build-prod-static/static/css/636-7b8794ea227293d474c9.css +0 -1
  57. package/build-prod-static/static/css/main-5aff2d8a2fc28d01fdad.css +0 -1
  58. package/build-prod-static/static/js/23-8e7dbd8910931f545fd9.js +0 -1
  59. package/build-prod-static/static/js/303-1db8abbd7d266bdc27c7.js +0 -1
  60. package/build-prod-static/static/js/636-8a26bc803f853c7ddf82.js +0 -1
  61. package/build-prod-static/static/js/main-709b08b8e9e528bab63c.js +0 -1
@@ -56,68 +56,66 @@ const Header = () => {
56
56
  }, [isBurgerActive]);
57
57
  return (
58
58
  <header
59
- className={`header ${
60
- isBurgerActive ? "off-scroll" : `${isScrolled ? "on-scroll" : ""}`
59
+ className={`${styles.header} ${
60
+ isBurgerActive
61
+ ? styles.offScroll
62
+ : `${isScrolled ? styles.onScroll : ""}`
61
63
  } `}
62
64
  id="header"
63
65
  >
64
- <nav className="navbar container">
65
- <a href="/" className="brand">
66
+ <nav className={`${styles.navbar} ${styles.container}`}>
67
+ <a href="/" className={`${styles.brand}`}>
66
68
  AFront
67
69
  </a>
68
70
  <div
69
- className={`burger ${isBurgerActive ? "is-active" : ""}`}
71
+ className={`${styles.burger} ${
72
+ isBurgerActive ? styles.isActive : ""
73
+ }`}
70
74
  id="burger"
71
75
  onClick={toggleMenu}
72
76
  >
73
- <span className="burger-line"></span>
74
- <span className="burger-line"></span>
75
- <span className="burger-line"></span>
77
+ <span className={styles.burgerLine}></span>
78
+ <span className={styles.burgerLine}></span>
79
+ <span className={styles.burgerLine}></span>
76
80
  </div>
77
81
  <div
78
- className={`menu ${isBurgerActive ? "is-active " : "is-inactive"}`}
82
+ className={`${styles.menu} ${
83
+ isBurgerActive ? styles.isActive : styles.isInActive
84
+ }`}
79
85
  id="menu"
80
86
  >
81
- <ul className="menu-inner">
82
- <li className="menu-item">
87
+ <ul className={styles.menuInner}>
88
+ <li className={styles.menuItem}>
83
89
  <a
84
90
  href="#"
85
- className={`menu-link ${
86
- isBurgerActive ? "menu-link-mobile" : ""
87
- }`}
91
+ className={`${styles.menuLink} ${isBurgerActive ? styles.menuLinkMobile : ""}`}
88
92
  onClick={closeMenu}
89
93
  >
90
94
  Learn
91
95
  </a>
92
96
  </li>
93
- <li className="menu-item">
97
+ <li className={styles.menuItem}>
94
98
  <a
95
99
  href="#"
96
- className={`menu-link ${
97
- isBurgerActive ? "menu-link-mobile" : ""
98
- }`}
100
+ className={`${styles.menuLink} ${isBurgerActive ? styles.menuLinkMobile : ""}`}
99
101
  onClick={closeMenu}
100
102
  >
101
103
  Feature
102
104
  </a>
103
105
  </li>
104
- <li className="menu-item">
106
+ <li className={styles.menuItem}>
105
107
  <a
106
108
  href="#"
107
- className={`menu-link ${
108
- isBurgerActive ? "menu-link-mobile" : ""
109
- }`}
109
+ className={`${styles.menuLink} ${isBurgerActive ? styles.menuLinkMobile : ""}`}
110
110
  onClick={closeMenu}
111
111
  >
112
112
  Blog
113
113
  </a>
114
114
  </li>
115
- <li className="menu-item">
115
+ <li className={styles.menuItem}>
116
116
  <a
117
117
  href="/support"
118
- className={`menu-link ${
119
- isBurgerActive ? "menu-link-mobile" : ""
120
- }`}
118
+ className={`${styles.menuLink} ${isBurgerActive ? styles.menuLinkMobile : ""}`}
121
119
  onClick={closeMenu}
122
120
  >
123
121
  Support
@@ -125,11 +123,11 @@ const Header = () => {
125
123
  </li>
126
124
  {isBurgerActive && (
127
125
  <>
128
- <li className="menu-item">
126
+ <li className={styles.menuItem}>
129
127
  <a
130
128
  href="#"
131
- className={`menu-link ${
132
- isBurgerActive ? "menu-link-mobile" : ""
129
+ className={`${styles.menuLink} ${
130
+ isBurgerActive ? styles.menuLinkMobile : ""
133
131
  }`}
134
132
  onClick={closeMenu}
135
133
  >
@@ -140,7 +138,7 @@ const Header = () => {
140
138
  )}
141
139
  </ul>
142
140
  </div>
143
- <a href="/" className="menu-block">
141
+ <a href="/" className={styles.menuBlock}>
144
142
  Get Started
145
143
  </a>
146
144
  </nav>
package/src/Pages/Home.js CHANGED
@@ -12,31 +12,38 @@ const Home = ({ context }) => {
12
12
  HeadTags({ title, description, keywords, context });
13
13
 
14
14
  return (
15
- <MeshGradient>
16
- <main className="main">
17
- <section className="section banner banner-section">
18
- <div className="container banner-column">
19
- <img className="banner-image" src={tensorlabLogo} alt="banner" />
20
- <div className="banner-inner">
21
- <h1 className="heading-xl">
22
- Empower Your Front-End with AFront
23
- </h1>
24
- <p className="paragraph">
25
- AFront streamlines front-end development with robust tools and
26
- <b> seamless server-side rendering (SSSR)</b>. Build dynamic,
27
- high-performance web experiences effortlessly.
28
- </p>
29
- <div className="btn-darken-block">
30
- <a href="/" className="btn-darken menu-block">
31
- Get Started{" "}
32
- <img className="btn-darken-arrow" src={arrowright} />
33
- </a>
34
- </div>
15
+ <MeshGradient>
16
+ <main>
17
+ <section className={styles.section}>
18
+ <div className={`${styles.container} ${styles.bannerColumn}`}>
19
+ <img
20
+ className={styles.bannerImage}
21
+ src={tensorlabLogo}
22
+ alt="banner"
23
+ />
24
+ <div className={styles.bannerInner}>
25
+ <h1 className={styles.headingXl}>
26
+ Empower Your Front-End with AFront
27
+ </h1>
28
+ <p className={styles.paragraph}>
29
+ AFront streamlines front-end development with robust tools and
30
+ <b> seamless server-side rendering (SSSR)</b>. Build dynamic,
31
+ high-performance web experiences effortlessly.
32
+ </p>
33
+ <div>
34
+ <a
35
+ href="/"
36
+ className={`${styles.btnDarken} ${styles.menuBlock}`}
37
+ >
38
+ Get Started{" "}
39
+ <img className={styles.btnDarkenArrow} src={arrowright} />
40
+ </a>
35
41
  </div>
36
42
  </div>
37
- </section>
38
- </main>
39
- </MeshGradient>
43
+ </div>
44
+ </section>
45
+ </main>
46
+ </MeshGradient>
40
47
  );
41
48
  };
42
49
 
@@ -1,5 +1,5 @@
1
1
  import React, { Suspense } from "react";
2
- import { Route, Routes } from "react-router-dom";
2
+ import { Route, Routes } from "react-router";
3
3
  import routes from "../ARoutes/AFRoutes.js";
4
4
  import LoadingFallback from "../LoadingFallback.js";
5
5
 
@@ -1,5 +1,5 @@
1
1
  import React, { Suspense } from "react";
2
- import { BrowserRouter as Router, Route, Routes } from "react-router-dom";
2
+ import { BrowserRouter as Router, Route, Routes } from "react-router";
3
3
  import routes from "../ARoutes/AFRoutes.js";
4
4
  import LoadingFallback from "../LoadingFallback.js";
5
5
 
@@ -7,7 +7,7 @@
7
7
  backdrop-filter: blur(10px);
8
8
  }
9
9
 
10
- .meshgradient>.color {
10
+ .meshgradient .color {
11
11
  width: 100%;
12
12
  height: 100%;
13
13
  display: flex;
@@ -112,7 +112,7 @@ video {
112
112
  margin-bottom: 1rem;
113
113
  }
114
114
 
115
- .heading-xl {
115
+ .headingXl {
116
116
  font-family: inherit;
117
117
  font-size: clamp(2.648rem, 6vw, 4.241rem);
118
118
  font-weight: 700;
@@ -181,7 +181,7 @@ video {
181
181
  column-gap: 0.5rem;
182
182
  }
183
183
 
184
- .btn-darken.menu-block {
184
+ .btnDarken.menuBlock {
185
185
  padding: 0.75rem 2rem;
186
186
  background-color: var(--color-black-200);
187
187
  border-bottom: none;
@@ -193,14 +193,14 @@ video {
193
193
  align-items: center;
194
194
  }
195
195
 
196
- .btn-darken-arrow {
196
+ .btnDarkenArrow {
197
197
  fill: #ffffff;
198
198
  height: 1rem;
199
199
  margin-left: 1rem;
200
200
  }
201
201
 
202
202
 
203
- .btn-darken.menu-block:hover {
203
+ .btnDarken.menuBlock:hover {
204
204
  border-bottom: 2px solid var(--color-blue-600);
205
205
  }
206
206
 
@@ -222,7 +222,7 @@ video {
222
222
  transition: all 0.3s ease;
223
223
  }
224
224
 
225
- .header.on-scroll {
225
+ .header.onScroll {
226
226
  background: var(--light);
227
227
  border-bottom: 1px solid var(--color-blue-800);
228
228
  box-shadow: var(--shadow-medium);
@@ -231,7 +231,7 @@ video {
231
231
  backdrop-filter: blur(10px);
232
232
  }
233
233
 
234
- .off-scroll {
234
+ .offScroll {
235
235
  border-bottom: 1px solid var(--color-blue-800);
236
236
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
237
237
  background-color: rgba(#ffffff, .2);
@@ -272,13 +272,13 @@ video {
272
272
 
273
273
 
274
274
 
275
- .menu-link.menu-link-mobile {
275
+ .menuLink.menuLinkMobile {
276
276
  padding: 0.5rem;
277
277
  padding-right: 1.5rem;
278
278
  padding-left: 1.5rem;
279
279
  }
280
280
 
281
- .menu-link.menu-link-mobile:hover {
281
+ .menuLink.menuLinkMobile:hover {
282
282
  border-bottom: none !important;
283
283
  background-color: rgba(35, 39, 47, .05);
284
284
  border-radius: 3rem;
@@ -294,7 +294,7 @@ video {
294
294
  box-shadow: var(--shadow-medium);
295
295
  }
296
296
 
297
- .menu.is-active {
297
+ .menu.isActive {
298
298
  top: 68px;
299
299
  width: 100%;
300
300
  height: 100vh;
@@ -302,21 +302,22 @@ video {
302
302
 
303
303
  }
304
304
 
305
- .menu.is-active .menu-inner {
305
+ .menu.isActive .menuInner {
306
306
  padding: 1rem;
307
307
  gap: 0.2rem;
308
308
  border-bottom: 0.75px solid #000000;
309
309
  }
310
310
 
311
+ .menuItem{}
311
312
 
312
313
 
313
- .menu.is-inactive {
314
+ .menu.isInActive {
314
315
  transition: opacity 0.4s ease-in-out;
315
316
  opacity: 0;
316
317
  visibility: hidden;
317
318
  }
318
319
 
319
- .menu-inner {
320
+ .menuInner {
320
321
  display: flex;
321
322
  overflow-x: auto;
322
323
  justify-content: space-around;
@@ -326,11 +327,11 @@ video {
326
327
 
327
328
  }
328
329
 
329
- .menu-inner::-webkit-scrollbar {
330
+ .menuInner::-webkit-scrollbar {
330
331
  display: none;
331
332
  }
332
333
 
333
- .menu-link {
334
+ .menuLink {
334
335
  font-family: inherit;
335
336
  font-size: 1rem;
336
337
  font-weight: 500;
@@ -339,7 +340,7 @@ video {
339
340
  margin-bottom: 0;
340
341
  }
341
342
 
342
- .menu-block {
343
+ .menuBlock {
343
344
  display: inline-block;
344
345
  font-family: inherit;
345
346
  font-size: 0.875rem;
@@ -371,24 +372,24 @@ video {
371
372
  transition: none;
372
373
  }
373
374
 
374
- .menu.is-inactive {
375
+ .menu.isInActive {
375
376
  transition: opacity 0.4s ease-in-out;
376
377
  opacity: 1;
377
378
  visibility: visible;
378
379
  }
379
380
 
380
- .menu-inner {
381
+ .menuInner {
381
382
  display: flex;
382
383
  flex-direction: row;
383
384
  column-gap: 2rem;
384
385
  margin: 0 auto;
385
386
  }
386
387
 
387
- .menu-link {
388
+ .menuLink {
388
389
  text-transform: capitalize;
389
390
  }
390
391
 
391
- .menu-block {
392
+ .menuBlock {
392
393
  margin-left: 2rem;
393
394
  }
394
395
  }
@@ -417,7 +418,7 @@ video {
417
418
  }
418
419
  }
419
420
 
420
- .burger-line {
421
+ .burgerLine {
421
422
  position: absolute;
422
423
  display: block;
423
424
  left: 0;
@@ -432,35 +433,35 @@ video {
432
433
  transition: 0.25s ease-in-out;
433
434
  }
434
435
 
435
- .burger-line:nth-child(1) {
436
+ .burgerLine:nth-child(1) {
436
437
  top: 0px;
437
438
  }
438
439
 
439
- .burger-line:nth-child(2) {
440
+ .burgerLine:nth-child(2) {
440
441
  top: 0.5rem;
441
442
  width: 70%;
442
443
  }
443
444
 
444
- .burger-line:nth-child(3) {
445
+ .burgerLine:nth-child(3) {
445
446
  top: 1rem;
446
447
  }
447
448
 
448
- .burger.is-active .burger-line:nth-child(1) {
449
+ .burger.isActive .burgerLine:nth-child(1) {
449
450
  top: 0.5rem;
450
451
  transform: rotate(135deg);
451
452
  }
452
453
 
453
- .burger.is-active .burger-line:nth-child(2) {
454
+ .burger.isActive .burgerLine:nth-child(2) {
454
455
  opacity: 0;
455
456
  visibility: hidden;
456
457
  }
457
458
 
458
- .burger.is-active .burger-line:nth-child(3) {
459
+ .burger.isActive .burgerLine:nth-child(3) {
459
460
  top: 0.5rem;
460
461
  transform: rotate(-135deg);
461
462
  }
462
463
 
463
- .banner-column {
464
+ .bannerColumn {
464
465
  position: relative;
465
466
  display: grid;
466
467
  align-items: center;
@@ -469,14 +470,14 @@ video {
469
470
  }
470
471
 
471
472
  @media only screen and (min-width: 48rem) {
472
- .banner-column {
473
+ .bannerColumn {
473
474
  grid-template-columns: repeat(2, minmax(0, 1fr));
474
475
  justify-content: center;
475
476
  }
476
477
  }
477
478
 
478
479
  @media only screen and (min-width: 64rem) {
479
- .banner-column {
480
+ .bannerColumn {
480
481
  grid-template-columns: 1fr max-content;
481
482
  column-gap: 4rem;
482
483
  margin-top: 3rem;
@@ -493,7 +494,7 @@ video {
493
494
  }
494
495
  }
495
496
 
496
- .banner-image {
497
+ .bannerImage {
497
498
  /* animation: rotate 60s linear infinite; */
498
499
  display: block;
499
500
  max-width: 18rem;
@@ -505,7 +506,7 @@ video {
505
506
  }
506
507
 
507
508
  @media only screen and (min-width: 48rem) {
508
- .banner-image {
509
+ .bannerImage {
509
510
  order: 1;
510
511
  max-width: 20rem;
511
512
  height: 20rem;
@@ -513,14 +514,14 @@ video {
513
514
  }
514
515
 
515
516
  @media only screen and (min-width: 64rem) {
516
- .banner-image {
517
+ .bannerImage {
517
518
  max-width: 25rem;
518
519
  height: 25rem;
519
520
  margin-right: 1rem;
520
521
  }
521
522
  }
522
523
 
523
- .banner-inner {
524
+ .bannerInner {
524
525
  display: flex;
525
526
  flex-direction: column;
526
527
  align-items: flex-start;
package/src/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import React from "react";
2
2
  import ReactDOM, { hydrateRoot } from "react-dom/client";
3
3
  import App from "./App";
4
- import { BrowserRouter } from "react-router-dom";
4
+ import { BrowserRouter } from "react-router";
5
5
 
6
6
  const container = document.getElementById("asggen");
7
7
 
@@ -26,4 +26,4 @@ if (process.env.NODE_ENV === "production") {
26
26
  </BrowserRouter>
27
27
  </React.StrictMode>
28
28
  );
29
- }
29
+ }
@@ -37,9 +37,8 @@ module.exports = {
37
37
  loader: "css-loader",
38
38
  options: {
39
39
  modules: {
40
- localIdentName: "[local]",
40
+ localIdentName: "asggen-[hash:base64:7]",
41
41
  },
42
- sourceMap: true,
43
42
  },
44
43
  },
45
44
  ],
package/webpack.prod.js CHANGED
@@ -34,7 +34,7 @@ module.exports = {
34
34
  loader: "css-loader",
35
35
  options: {
36
36
  modules: {
37
- localIdentName: "[local]",
37
+ localIdentName: "asggen-[hash:base64:7]",
38
38
  },
39
39
  },
40
40
  },
@@ -34,7 +34,7 @@ module.exports = {
34
34
  loader: "css-loader",
35
35
  options: {
36
36
  modules: {
37
- localIdentName: "[local]",
37
+ localIdentName: "asggen-[hash:base64:7]",
38
38
  },
39
39
  },
40
40
  },
@@ -1 +0,0 @@
1
- .supportContainer{align-items:center;background:#f7f9fc;color:#333;display:flex;flex-direction:column;justify-content:center;min-height:100vh;overflow:hidden;padding:5rem 2rem;position:relative;text-align:center}.supportTitle{color:#2c3e50;font-size:3rem;font-weight:700;margin-bottom:1rem}.supportDescription{color:#34495e;font-size:1.25rem;margin-bottom:2rem}.supportContent{margin:0 auto;max-width:900px;padding:1rem}.supportCard{background:#fff;border-radius:8px;box-shadow:0 4px 8px rgba(0,0,0,.1);color:#2c3e50;margin-bottom:2rem;overflow:hidden;padding:2rem;position:relative;transition:transform .3s ease,box-shadow .3s ease}.supportCard:before{background:linear-gradient(45deg,rgba(0,255,238,.2),rgba(0,49,109,.2));content:"";height:300%;left:50%;opacity:0;position:absolute;top:50%;transform:translate(-50%,-50%) rotate(0deg);transition:opacity .3s ease;width:300%;z-index:0}.supportCardTitle{font-size:1.5rem;margin-bottom:1rem;position:relative;z-index:1}.supportCardContent{font-size:1rem;position:relative;z-index:1}.supportCard:hover{box-shadow:0 8px 16px rgba(0,0,0,.2);transform:translateY(-10px)}.supportCard:hover:before{opacity:1}.footerLink{background:#3498db;border-radius:4px;color:#fff;display:inline-block;margin-top:2rem;overflow:hidden;padding:.5rem 1rem;position:relative;text-decoration:none;transition:background .3s,transform .3s}.footerLink:after{background:radial-gradient(circle,hsla(0,0%,100%,.2) 0,hsla(0,0%,100%,0) 70%);content:"";height:300%;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%) scale(0);transition:transform .3s;width:300%;z-index:0}.footerLink:hover{background:#2980b9;transform:scale(1.05)}.footerLink:hover:after{transform:translate(-50%,-50%) scale(1)}.supportContainer:before{color:rgba(0,0,0,.1);content:"AFront";font-size:15rem;left:50%;pointer-events:none;position:absolute;top:2%;transform:translateX(-50%);white-space:nowrap;z-index:0}.supportFAQ{background:#fff;border-radius:8px;box-shadow:0 4px 8px rgba(0,0,0,.1);margin:2rem auto;max-width:900px;padding:1rem;text-align:left}.faqList{color:#2c3e50;font-size:1rem;list-style-type:none;padding:0}.faqList li{margin-bottom:1rem}@media (max-width:768px){.supportTitle{font-size:2.5rem}.supportDescription{font-size:1rem}.supportCard{padding:1rem}.supportCardTitle{font-size:1.25rem}.supportCardContent{font-size:.875rem}.supportContainer:before{bottom:5%;font-size:5rem}}.gradientWrap{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:rgba(var(--light),.2);overflow:hidden;position:relative;width:100%}.meshgradient>.color{align-items:center;background-repeat:no-repeat;bottom:0;display:flex;height:100%;left:0;margin:auto;mix-blend-mode:overlay;position:absolute;right:0;top:0;transform:scale(3) rotate(0deg);width:100%}.c1{animation:c1 8s linear infinite;background:radial-gradient(#dfa39b 25%,transparent 50%);background-position:0 0;background-size:60% 80%}.c2{animation:c2 10s linear infinite;background:radial-gradient(#aa8de3 25%,transparent 50%);background-position:0 100%;background-size:70% 80%}.c3{animation:c3 5s linear infinite;background:radial-gradient(#d1a0c4 25%,transparent 50%);background-position:50% 0;background-size:80% 80%}.c4{animation:c4 6s linear infinite;background:radial-gradient(#52bce9 25%,transparent 50%);background-position:50% 100%;background-size:80% 80%}@keyframes c1{25%{background-position:25% 50%;background-size:70% 70%;transform:scale(3) rotate(-45deg)}50%{background-position:50% 100%;background-size:80% 80%;transform:scale(3) rotate(-75deg)}75%{background-position:75% 50%;background-size:60% 60%;transform:scale(3) rotate(-30deg)}}@keyframes c2{25%{background-position:25% 0;background-size:60% 60%;transform:scale(3) rotate(45deg)}50%{background-position:50% 0;background-size:80% 80%;transform:scale(3) rotate(90deg)}75%{background-position:75% 0;background-size:70% 70%;transform:scale(3) rotate(135deg)}}@keyframes c3{25%{background-position:50% 50%;background-size:90% 90%;transform:scale(3) rotate(-15deg)}50%{background-position:0 100%;background-size:70% 80%;transform:scale(3) rotate(8deg)}75%{background-position:50% 50%;background-size:60% 70%;transform:scale(3) rotate(-10deg)}}@keyframes c4{25%{background-position:100% 0;transform:scale(3) rotate(30deg)}50%{background-position:0 0;transform:scale(3) rotate(-36deg)}75%{background-position:50% 50%;transform:scale(3) rotate(0deg)}}
@@ -1 +0,0 @@
1
- .gradientWrap{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:rgba(var(--light),.2);overflow:hidden;position:relative;width:100%}.meshgradient>.color{align-items:center;background-repeat:no-repeat;bottom:0;display:flex;height:100%;left:0;margin:auto;mix-blend-mode:overlay;position:absolute;right:0;top:0;transform:scale(3) rotate(0deg);width:100%}.c1{animation:c1 8s linear infinite;background:radial-gradient(#dfa39b 25%,transparent 50%);background-position:0 0;background-size:60% 80%}.c2{animation:c2 10s linear infinite;background:radial-gradient(#aa8de3 25%,transparent 50%);background-position:0 100%;background-size:70% 80%}.c3{animation:c3 5s linear infinite;background:radial-gradient(#d1a0c4 25%,transparent 50%);background-position:50% 0;background-size:80% 80%}.c4{animation:c4 6s linear infinite;background:radial-gradient(#52bce9 25%,transparent 50%);background-position:50% 100%;background-size:80% 80%}@keyframes c1{25%{background-position:25% 50%;background-size:70% 70%;transform:scale(3) rotate(-45deg)}50%{background-position:50% 100%;background-size:80% 80%;transform:scale(3) rotate(-75deg)}75%{background-position:75% 50%;background-size:60% 60%;transform:scale(3) rotate(-30deg)}}@keyframes c2{25%{background-position:25% 0;background-size:60% 60%;transform:scale(3) rotate(45deg)}50%{background-position:50% 0;background-size:80% 80%;transform:scale(3) rotate(90deg)}75%{background-position:75% 0;background-size:70% 70%;transform:scale(3) rotate(135deg)}}@keyframes c3{25%{background-position:50% 50%;background-size:90% 90%;transform:scale(3) rotate(-15deg)}50%{background-position:0 100%;background-size:70% 80%;transform:scale(3) rotate(8deg)}75%{background-position:50% 50%;background-size:60% 70%;transform:scale(3) rotate(-10deg)}}@keyframes c4{25%{background-position:100% 0;transform:scale(3) rotate(30deg)}50%{background-position:0 0;transform:scale(3) rotate(-36deg)}75%{background-position:50% 50%;transform:scale(3) rotate(0deg)}}
@@ -1 +0,0 @@
1
- .pageNotFoundContainer{align-items:center;background-color:#f0f4f8;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px;text-align:center}.heading{color:#333;font-size:2.5rem;margin-bottom:20px;text-shadow:1px 1px 2px rgba(0,0,0,.1)}.subText{color:#666;font-size:1.2rem;margin-bottom:30px}.homeLink{background-color:#007bff;border-radius:5px;color:#fff;font-size:1rem;padding:10px 20px;text-decoration:none;transition:background-color .3s ease}.homeLink:hover{background-color:#0056b3}
@@ -1 +0,0 @@
1
- @import url(https://fonts.googleapis.com/css2?family=Rubik:wght@400;500;600;700&display=swap);.loadingContainer{align-items:center;display:flex;height:100vh;justify-content:center}.loadingLogo{height:auto;width:150px}:root{--light:#fff;--dark:#000;--color-white-100:#fff;--color-white-200:#e4e6e7;--color-white-300:#c9cccf;--color-white-400:#a1a6aa;--color-white-500:#798086;--color-black-100:#14191f;--color-black-200:#101419;--color-black-300:#0c0f13;--color-black-400:#0c0f13;--color-black-500:#080a0c;--color-black-600:#060709;--color-black-700:#040506;--color-black-800:#020303;--color-blue-100:#dcebfe;--color-blue-200:#bedbfe;--color-blue-300:#91c3fd;--color-blue-400:#61a6fa;--color-blue-500:#3c83f6;--color-blue-600:#2463eb;--color-blue-700:#1d4fd7;--color-blue-800:#1e3fae;--color-blue-900:#1e3b8a;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 16px 32px -16px rgba(0,0,0,.1),0 0 0 1px rgba(0,0,0,.1);--base__color-2__rgb:32,32,32;--shadow-small:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06);--shadow-medium:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);--shadow-large:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05)}*,:after,:before{box-sizing:border-box;list-style:none;list-style-type:none;margin:0;padding:0;text-decoration:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}html{box-sizing:inherit;font-size:100%;scroll-behavior:smooth}body,html{height:-webkit-fill-available}body{font-family:Rubik,sans-serif;font-size:clamp(1rem,2vw,1.125rem);font-weight:400;line-height:1.5;min-width:320px}main{overflow:hidden}a,button{background:none;border:none;box-shadow:none;cursor:pointer;outline:none;text-decoration:none;user-select:none}a{color:var(--color-black-400)}img,video{display:block;height:auto;max-width:100%;object-fit:cover}.section{margin:0 auto;padding:6rem 0 8rem}.container{height:auto;margin:0 auto;max-width:75rem}.centered{margin-bottom:1rem;text-align:center;vertical-align:middle}.heading-xl{font-size:clamp(2.648rem,6vw,4.241rem)}.heading-lg,.heading-xl{font-family:inherit;font-weight:700;letter-spacing:-1px;line-height:1.15}.heading-lg{font-size:clamp(2.179rem,5vw,3.176rem)}.heading-md{font-family:inherit;font-size:clamp(1.794rem,4vw,2.379rem);font-weight:700;letter-spacing:-1px;line-height:1.25}.heading-sm{font-size:clamp(1.476rem,3vw,1.782rem);font-weight:600}.heading-sm,.heading-xs{font-family:inherit;line-height:1.5}.heading-xs{font-size:clamp(1.215rem,2vw,1.335rem);font-weight:500}.paragraph{font-size:clamp(1rem,2vw,1.125rem);text-wrap:balance}.btn,.paragraph{font-family:inherit}.btn{border:none;border-radius:.75rem;display:inline-block;font-size:1rem;font-weight:500;line-height:1.5;outline:none;text-align:center;text-transform:unset;user-select:none;vertical-align:middle;white-space:nowrap}.btn-inline{column-gap:.5rem;display:inline-flex}.btn-darken.menu-block,.btn-inline{align-items:center;justify-content:center}.btn-darken.menu-block{background-color:var(--color-black-200);border-bottom:none;display:flex;height:2.7rem;line-height:0;margin-left:0;padding:.75rem 2rem}.btn-darken-arrow{fill:#fff;height:1rem;margin-left:1rem}.btn-darken.menu-block:hover{border-bottom:2px solid var(--color-blue-600)}.btn-neutral{background-color:var(--color-white-100);box-shadow:var(--shadow-medium);color:var(--color-black-500);padding:.75rem 2rem}.header{height:auto;left:0;margin:0 auto;position:fixed;top:0;transition:all .3s ease;width:100%;z-index:100}.header.on-scroll{background:var(--light);background-color:rgba(var(--light),.2);box-shadow:var(--shadow-medium)}.header.on-scroll,.off-scroll{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-blue-800)}.off-scroll{background-color:rgba(#ffffff,.2);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.navbar{align-items:center;column-gap:1.25rem;display:flex;flex-direction:row;height:4.25rem;justify-content:flex-start;margin:0 auto;width:100%}.brand{font-family:inherit;font-size:1.6rem;font-weight:600;letter-spacing:-1px;line-height:1.5;margin-bottom:0}.navbar.container{margin-bottom:0;padding:0 1.25rem}.navbar.container a:hover{border-bottom:2px solid var(--color-black-800)}.menu-link.menu-link-mobile{padding:.5rem 1.5rem}.menu-link.menu-link-mobile:hover{background-color:rgba(35,39,47,.05);border-bottom:none!important;border-radius:3rem}.menu{background-color:var(--light);box-shadow:var(--shadow-medium);height:auto;left:0;position:fixed;top:-100%;width:100%}.menu.is-active{border-top:1px solid var(--color-blue-800);height:100vh;top:68px;width:100%}.menu.is-active .menu-inner{border-bottom:.75px solid #000;gap:.2rem;padding:1rem}.menu.is-inactive{opacity:0;transition:opacity .4s ease-in-out;visibility:hidden}.menu-inner{display:flex;justify-content:space-around;overflow-x:auto;row-gap:1.25rem;-ms-overflow-style:none;scrollbar-width:none}.menu-inner::-webkit-scrollbar{display:none}.menu-link{font-size:1rem;line-height:1.5;text-transform:uppercase}.menu-block,.menu-link{font-family:inherit;font-weight:500;margin-bottom:0}.menu-block{background-color:var(--color-blue-600);border-radius:.75rem;box-shadow:var(--shadow-medium);color:var(--light);display:inline-block;font-size:.875rem;line-height:1.25;margin-left:auto;padding:.65rem 1.5rem;text-align:center;text-transform:capitalize;user-select:none;white-space:nowrap}@media only screen and (min-width:48rem){.menu{background:none;box-shadow:none;height:auto;margin-left:auto;padding:0;position:relative;top:0;transition:none;width:auto}.menu.is-inactive{opacity:1;transition:opacity .4s ease-in-out;visibility:visible}.menu-inner{column-gap:2rem;display:flex;flex-direction:row;margin:0 auto}.menu-link{text-transform:capitalize}.menu-block{margin-left:2rem}}.burger{background:none;border:none;cursor:pointer;display:block;height:1.15rem;order:-1;outline:none;position:relative;transform:rotate(0deg);transition:.35s ease;user-select:none;visibility:visible;width:1.6rem;z-index:10}@media only screen and (min-width:48rem){.burger{display:none;visibility:hidden}}.burger-line{background-color:var(--color-black-800);border:none;border-radius:1rem;display:block;height:2px;left:0;opacity:1;outline:none;position:absolute;transform:rotate(0deg);transition:.25s ease-in-out;width:100%}.burger-line:first-child{top:0}.burger-line:nth-child(2){top:.5rem;width:70%}.burger-line:nth-child(3){top:1rem}.burger.is-active .burger-line:first-child{top:.5rem;transform:rotate(135deg)}.burger.is-active .burger-line:nth-child(2){opacity:0;visibility:hidden}.burger.is-active .burger-line:nth-child(3){top:.5rem;transform:rotate(-135deg)}.banner-column{align-items:center;display:grid;padding:0 1rem;position:relative;row-gap:3rem}@media only screen and (min-width:48rem){.banner-column{grid-template-columns:repeat(2,minmax(0,1fr));justify-content:center}}@media only screen and (min-width:64rem){.banner-column{column-gap:4rem;grid-template-columns:1fr max-content;margin-top:3rem}}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.banner-image{display:block;height:18rem;justify-self:center;margin-top:2rem;max-width:18rem;object-fit:cover}@media only screen and (min-width:48rem){.banner-image{height:20rem;max-width:20rem;order:1}}@media only screen and (min-width:64rem){.banner-image{height:25rem;margin-right:1rem;max-width:25rem}}.banner-inner{align-items:flex-start;display:flex;flex-direction:column;row-gap:1.75rem}.footer{background-color:#fff;color:#333;overflow:hidden;padding:2.5rem 0;position:relative}.footer:before{color:rgba(0,0,0,.05);content:"AFront";font-size:20rem;left:50%;pointer-events:none;position:absolute;top:70%;transform:translate(-50%,-50%);white-space:nowrap;z-index:0}.footerContainer{align-items:flex-start;display:flex;flex-wrap:wrap;justify-content:space-between;margin:0 auto;max-width:75rem;padding:0 1.25rem;position:relative;z-index:1}.footerBrand{flex:1;margin-bottom:2rem}.footerLogo{color:var(--color-black-400);font-size:1.5rem;font-weight:700;text-decoration:none}.footerDescription{color:#8b8b8b;font-size:.875rem;margin-top:.625rem}.footerLinks{display:flex;flex:2;flex-wrap:wrap;justify-content:space-between}.linkColumn{flex:1;margin-bottom:2rem;min-width:12rem}.footerTitle{color:#777;font-size:1rem;margin-bottom:.625rem}.linkList{list-style:none;padding:0}.link{color:#909090;display:block;font-size:.875rem;margin-bottom:.5rem;text-decoration:none;transition:color .3s ease}.link:hover{color:#3a3a3a}.footerBottom{color:#777;font-size:.875rem;margin-top:2.5rem;text-align:center}.footerCopy{margin-bottom:.625rem}.socialLinks{display:flex;flex-wrap:wrap;justify-content:center}.socialLink{color:#909090;font-size:1.125rem;margin:0 .625rem;text-decoration:none;transition:color .3s ease}.socialLink:hover{color:#3a3a3a}@media (max-width:768px){.footerContainer,.footerLinks{align-items:center;flex-direction:column}.footerLinks{text-align:center}.linkColumn{margin-bottom:1.5rem}.footerCopy{font-size:.75rem}.socialLinks{margin-top:1rem}.socialLink{font-size:1rem;margin:0 .5rem}.footer:before{content:"AFront";font-size:5rem;top:82%}}
@@ -1 +0,0 @@
1
- (self.webpackChunkafront=self.webpackChunkafront||[]).push([[3],{572:(e,t,a)=>{const{useEffect:r}=a(540);function n(e,t){if(t){let a=document.querySelector(`meta[name="${e}"]`);a?a.setAttribute("content",t):(a=document.createElement("meta"),a.setAttribute("name",e),a.setAttribute("content",t),document.head.appendChild(a))}}e.exports=function({title:e,description:t,keywords:a,context:s}){r((()=>{"undefined"!=typeof document&&(document.title=e,n("title",e),n("description",t),n("keywords",a))}),[e,t,a]),s&&(s.title=e,s.description=t,s.keywords=a)}},210:(e,t,a)=>{"use strict";a.d(t,{A:()=>s});var r=a(540),n="color";const s=function(e){var t=e.children;return r.createElement("div",{className:"gradientWrap"},r.createElement("div",{className:"meshgradient"},r.createElement("div",{className:"".concat(n," ").concat("c1")}),r.createElement("div",{className:"".concat(n," ").concat("c2")}),r.createElement("div",{className:"".concat(n," ").concat("c3")}),r.createElement("div",{className:"".concat(n," ").concat("c4")})),t)}},3:(e,t,a)=>{"use strict";a.r(t),a.d(t,{default:()=>m});var r=a(540),n=a(572),s=a.n(n),o="supportCard",c="supportCardContent",i="supportCardTitle",l=a(210);const m=function(e){var t=e.context;return s()({title:"Support - AFront",description:"Get support for AFront, a front-end JavaScript library for seamless server-side rendering.",keywords:"support, AFront, server-side rendering, JavaScript",context:t}),r.createElement(l.A,null,r.createElement("div",{className:"supportContainer"},r.createElement("h1",{className:"supportTitle"},"Need Assistance?"),r.createElement("p",{className:"supportDescription"},"AFront is a cutting-edge front-end JavaScript library designed for seamless server-side rendering (SSR). We're committed to providing you with top-notch support to ensure your experience is smooth and productive."),r.createElement("div",{className:"supportContent"},r.createElement("div",{className:o},r.createElement("h2",{className:i},"Technical Assistance"),r.createElement("p",{className:c},"Our dedicated technical support team is available around the clock to resolve any issues you may face with AFront. Connect with us through email or our support portal for prompt assistance.")),r.createElement("div",{className:o},r.createElement("h2",{className:i},"Product Information"),r.createElement("p",{className:c},"Curious about AFront’s capabilities? Reach out to our sales team for detailed insights on features, benefits, and how our library can enhance your web development projects.")),r.createElement("div",{className:o},r.createElement("h2",{className:i},"Community and Forums"),r.createElement("p",{className:c},"Join our vibrant community forums to discuss AFront with fellow developers, exchange tips, and troubleshoot common issues collaboratively."))),r.createElement("div",{className:"supportFAQ"},r.createElement("h2",{className:i},"Frequently Asked Questions"),r.createElement("ul",{className:"faqList"},r.createElement("li",null,"What is AFront and how does it work?"),r.createElement("li",null,"How do I get started with AFront?"),r.createElement("li",null,"Where can I find documentation and tutorials?"),r.createElement("li",null,"How can I report a bug or request a feature?"))),r.createElement("a",{href:"/",className:"footerLink"},"Back to Homepage")))}}}]);
@@ -1 +0,0 @@
1
- (self.webpackChunkafront=self.webpackChunkafront||[]).push([[41],{572:(e,t,n)=>{const{useEffect:a}=n(540);function c(e,t){if(t){let n=document.querySelector(`meta[name="${e}"]`);n?n.setAttribute("content",t):(n=document.createElement("meta"),n.setAttribute("name",e),n.setAttribute("content",t),document.head.appendChild(n))}}e.exports=function({title:e,description:t,keywords:n,context:r}){a((()=>{"undefined"!=typeof document&&(document.title=e,c("title",e),c("description",t),c("keywords",n))}),[e,t,n]),r&&(r.title=e,r.description=t,r.keywords=n)}},210:(e,t,n)=>{"use strict";n.d(t,{A:()=>r});var a=n(540),c="color";const r=function(e){var t=e.children;return a.createElement("div",{className:"gradientWrap"},a.createElement("div",{className:"meshgradient"},a.createElement("div",{className:"".concat(c," ").concat("c1")}),a.createElement("div",{className:"".concat(c," ").concat("c2")}),a.createElement("div",{className:"".concat(c," ").concat("c3")}),a.createElement("div",{className:"".concat(c," ").concat("c4")})),t)}},488:(e,t,n)=>{"use strict";n.r(t),n.d(t,{default:()=>i});var a=n(540),c=n(210);const r=n.p+"static/media/52f06bb716d4ecad087a.png",s=n.p+"static/media/adeaead125c45715106d.svg";var o=n(572),l=n.n(o);const i=function(e){var t=e.context;return l()({title:"AFront by Asggen Inc.",description:"Home for all AFront products and services.",keywords:"Home, Afront, help",context:t}),a.createElement(c.A,null,a.createElement("main",{className:"main"},a.createElement("section",{className:"section banner banner-section"},a.createElement("div",{className:"container banner-column"},a.createElement("img",{className:"banner-image",src:r,alt:"banner"}),a.createElement("div",{className:"banner-inner"},a.createElement("h1",{className:"heading-xl"},"Empower Your Front-End with AFront"),a.createElement("p",{className:"paragraph"},"AFront streamlines front-end development with robust tools and",a.createElement("b",null," seamless server-side rendering (SSSR)"),". Build dynamic, high-performance web experiences effortlessly."),a.createElement("div",{className:"btn-darken-block"},a.createElement("a",{href:"/",className:"btn-darken menu-block"},"Get Started"," ",a.createElement("img",{className:"btn-darken-arrow",src:s}))))))))}}}]);
@@ -1 +0,0 @@
1
- "use strict";(self.webpackChunkafront=self.webpackChunkafront||[]).push([[573],{573:(e,a,t)=>{t.r(a),t.d(a,{default:()=>o});var n=t(540);const o=function(){return n.createElement("div",{className:"pageNotFoundContainer"},n.createElement("h2",{className:"heading"},"Oops! The page you're looking for doesn't exist."),n.createElement("p",{className:"subText"},"It seems you’ve taken a wrong turn. Let’s get you back on track!"),n.createElement("a",{href:"/",className:"homeLink"},"Go to Homepage"))}}}]);