@roadlittledawn/docs-design-system-react 0.4.0 → 0.6.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/dist/styles.css CHANGED
@@ -224,6 +224,38 @@
224
224
  --dds-tabs-tab-border-active: #3b82f6; /* blue-500 */
225
225
  --dds-tabs-panel-padding: 1.25rem 0;
226
226
  --dds-tabs-panel-text: #111827; /* gray-900 */
227
+
228
+ /* Popover */
229
+ --dds-popover-bg: #ffffff;
230
+ --dds-popover-border: #e5e7eb; /* gray-200 */
231
+ --dds-popover-radius: 0.5rem; /* rounded-lg */
232
+ --dds-popover-shadow:
233
+ 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 10px 15px -3px rgba(0, 0, 0, 0.1),
234
+ 0 2px 4px -1px rgba(0, 0, 0, 0.06);
235
+ --dds-popover-text: #374151; /* gray-700 */
236
+ --dds-popover-title-color: #111827; /* gray-900 */
237
+ --dds-popover-eyebrow-color: #6b7280; /* gray-500 */
238
+ --dds-popover-link-color: #2563eb; /* blue-600 */
239
+ --dds-popover-link-color-hover: #1e40af; /* blue-800 */
240
+ --dds-popover-width-sm: 240px;
241
+ --dds-popover-width-md: 320px;
242
+ --dds-popover-width-lg: 480px;
243
+ --dds-popover-padding: 1rem;
244
+ --dds-popover-image-height: 120px;
245
+ --dds-popover-title-size: 0.9375rem; /* ~15px */
246
+ --dds-popover-text-size: 0.875rem; /* text-sm */
247
+ --dds-popover-eyebrow-size: 0.6875rem; /* ~11px */
248
+
249
+ /* List */
250
+ --dds-list-margin: 1.5rem 0;
251
+ --dds-list-item-margin-bottom: 1.5rem;
252
+ --dds-list-badge-size: calc(var(--dds-line-height-relaxed) * 1rem);
253
+ --dds-list-badge-font-size: 0.8125rem;
254
+ --dds-list-badge-text: #171a1c; /* gray-900 */
255
+ --dds-list-badge-bg: #eceef2;
256
+ --dds-list-badge-shadow: inset 0 0 0 1px #bfc2c7;
257
+ --dds-list-connector-line: #eceef2; /* gray-200 */
258
+ --dds-list-text: #374151; /* gray-700 */
227
259
  }
228
260
  /* ==========================================================================
229
261
  Dark Mode Tokens
@@ -365,6 +397,25 @@
365
397
  --dds-prism-keyword: #60a5fa; /* blue-400 */
366
398
  --dds-prism-function: #a78bfa; /* violet-400 */
367
399
  --dds-prism-regex: #fb923c; /* orange-400 */
400
+
401
+ /* Popover */
402
+ --dds-popover-bg: #1f2937; /* gray-800 */
403
+ --dds-popover-border: #4b5563; /* gray-600 */
404
+ --dds-popover-shadow:
405
+ 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 10px 15px -3px rgba(0, 0, 0, 0.4),
406
+ 0 2px 4px -1px rgba(0, 0, 0, 0.2);
407
+ --dds-popover-text: #e5e7eb; /* gray-200 */
408
+ --dds-popover-title-color: #f9fafb; /* gray-50 */
409
+ --dds-popover-eyebrow-color: #9ca3af; /* gray-400 */
410
+ --dds-popover-link-color: #60a5fa; /* blue-400 */
411
+ --dds-popover-link-color-hover: #93c5fd; /* blue-300 */
412
+
413
+ /* List */
414
+ --dds-list-badge-text: #ffffff;
415
+ --dds-list-badge-bg: #232831;
416
+ --dds-list-badge-shadow: inset 0 0 0 1px #353a42;
417
+ --dds-list-connector-line: #353a42; /* gray-600 */
418
+ --dds-list-text: #e5e7eb; /* gray-200 */
368
419
  }
369
420
  /* Auto dark mode — follows OS preference, opt-out with .dds-light */
370
421
  @media (prefers-color-scheme: dark) {
@@ -501,6 +552,25 @@
501
552
  --dds-prism-keyword: #60a5fa;
502
553
  --dds-prism-function: #a78bfa;
503
554
  --dds-prism-regex: #fb923c;
555
+
556
+ /* Popover */
557
+ --dds-popover-bg: #1f2937;
558
+ --dds-popover-border: #4b5563;
559
+ --dds-popover-shadow:
560
+ 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 10px 15px -3px rgba(0, 0, 0, 0.4),
561
+ 0 2px 4px -1px rgba(0, 0, 0, 0.2);
562
+ --dds-popover-text: #e5e7eb;
563
+ --dds-popover-title-color: #f9fafb;
564
+ --dds-popover-eyebrow-color: #9ca3af;
565
+ --dds-popover-link-color: #60a5fa;
566
+ --dds-popover-link-color-hover: #93c5fd;
567
+
568
+ /* List */
569
+ --dds-list-badge-text: #ffffff;
570
+ --dds-list-badge-bg: #232831;
571
+ --dds-list-badge-shadow: inset 0 0 0 1px #353a42;
572
+ --dds-list-connector-line: #353a42; /* gray-600 */
573
+ --dds-list-text: #e5e7eb; /* gray-200 */
504
574
  }
505
575
  }
506
576
  /* Explicit dark mode via data attribute (overrides OS preference) */
@@ -626,6 +696,18 @@
626
696
  --dds-prism-keyword: #60a5fa;
627
697
  --dds-prism-function: #a78bfa;
628
698
  --dds-prism-regex: #fb923c;
699
+
700
+ /* Popover */
701
+ --dds-popover-bg: #1f2937;
702
+ --dds-popover-border: #4b5563;
703
+ --dds-popover-shadow:
704
+ 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 10px 15px -3px rgba(0, 0, 0, 0.4),
705
+ 0 2px 4px -1px rgba(0, 0, 0, 0.2);
706
+ --dds-popover-text: #e5e7eb;
707
+ --dds-popover-title-color: #f9fafb;
708
+ --dds-popover-eyebrow-color: #9ca3af;
709
+ --dds-popover-link-color: #60a5fa;
710
+ --dds-popover-link-color-hover: #93c5fd;
629
711
  }
630
712
  /* Import PrismJS theme */
631
713
  /**
@@ -1409,4 +1491,313 @@ a.no-text-decoration {
1409
1491
  margin-bottom: 0.25rem; /* mb-1 */
1410
1492
  vertical-align: middle;
1411
1493
  }
1494
+ .dds-list {
1495
+ list-style: none;
1496
+ counter-reset: list-counter;
1497
+ padding-left: 0;
1498
+ margin: var(--dds-list-margin, 1.5rem 0);
1499
+ color: var(--dds-list-text);
1500
+ }
1501
+ .dds-list[data-ordered="false"] {
1502
+ counter-reset: none;
1503
+ }
1504
+ .dds-list-item {
1505
+ counter-increment: list-counter;
1506
+ position: relative;
1507
+ padding-inline-start: calc(var(--dds-list-badge-size) + 1rem);
1508
+ margin-bottom: var(--dds-list-item-margin-bottom, 1.5rem);
1509
+ min-height: var(--dds-list-badge-size);
1510
+ }
1511
+ .dds-list[data-ordered="false"] .dds-list-item {
1512
+ counter-increment: none;
1513
+ }
1514
+ .dds-list-item::after {
1515
+ content: "";
1516
+ position: absolute;
1517
+ top: calc(var(--dds-list-badge-size, 2.5rem) + 0.5rem);
1518
+ bottom: calc(-1 * var(--dds-list-item-margin-bottom, 1.5rem) + 0.5rem);
1519
+ left: calc((var(--dds-list-badge-size, 2.5rem) - 1px) / 2);
1520
+ width: 1px;
1521
+ background-color: var(--dds-list-connector-line);
1522
+ }
1523
+ .dds-list-item:last-child::after {
1524
+ display: none;
1525
+ }
1526
+ /* Ordered list badges */
1527
+ .dds-list[data-ordered="true"] .dds-list-item::before {
1528
+ content: counter(list-counter);
1529
+ position: absolute;
1530
+ left: 0;
1531
+ top: 0;
1532
+ width: var(--dds-list-badge-size, 2.5rem);
1533
+ height: var(--dds-list-badge-size, 2.5rem);
1534
+ line-height: var(--dds-line-height-relaxed);
1535
+ inset-inline-start: 0;
1536
+ display: flex;
1537
+ align-items: center;
1538
+ justify-content: center;
1539
+ font-weight: var(--dds-font-bold, 700);
1540
+ font-size: var(--dds-list-badge-font-size, 1.125rem);
1541
+ color: var(--dds-list-badge-text);
1542
+ background: var(--dds-list-badge-bg);
1543
+ box-shadow: var(--dds-list-badge-shadow);
1544
+ border-radius: 50%;
1545
+ }
1546
+ /* Unordered list bullets */
1547
+ .dds-list[data-ordered="false"] .dds-list-item::before {
1548
+ content: var(--dds-list-bullet, "•");
1549
+ position: absolute;
1550
+ left: 0;
1551
+ top: 0;
1552
+ width: var(--dds-list-badge-size, 2.5rem);
1553
+ height: var(--dds-list-badge-size, 2.5rem);
1554
+ inset-inline-start: 0;
1555
+ display: flex;
1556
+ align-items: center;
1557
+ justify-content: center;
1558
+ font-size: var(--dds-list-bullet-size, 1.5rem);
1559
+ color: var(--dds-list-badge-text);
1560
+ }
1561
+ /* Hide ::before when using custom icon */
1562
+ .dds-list[data-has-icon="true"] .dds-list-item::before {
1563
+ display: none;
1564
+ }
1565
+ /* Custom icon bullet */
1566
+ .dds-list-item-icon {
1567
+ position: absolute;
1568
+ left: 0;
1569
+ top: 0;
1570
+ width: var(--dds-list-badge-size, 2.5rem);
1571
+ height: var(--dds-list-badge-size, 2.5rem);
1572
+ display: flex;
1573
+ align-items: center;
1574
+ justify-content: center;
1575
+ color: var(--dds-list-badge-text);
1576
+ }
1577
+ .dds-list-item-icon svg {
1578
+ width: 1.25rem;
1579
+ height: 1.25rem;
1580
+ }
1581
+ /* ==========================================================================
1582
+ Popover Component
1583
+ Uses the native Popover API for top-layer rendering.
1584
+ Positioning is handled via inline styles set by JS (getBoundingClientRect).
1585
+ ========================================================================== */
1586
+ /* Trigger */
1587
+ .dds-popover-trigger {
1588
+ display: inline;
1589
+ cursor: default;
1590
+ text-decoration-line: underline;
1591
+ text-decoration-style: dotted;
1592
+ text-decoration-color: currentColor;
1593
+ text-underline-offset: 3px;
1594
+ border-radius: 2px;
1595
+ outline-offset: 2px;
1596
+ }
1597
+ .dds-popover-trigger:focus-visible {
1598
+ outline: 2px solid var(--dds-link-color);
1599
+ }
1600
+ /* ==========================================================================
1601
+ Popover panel — rendered in the top layer via Popover API
1602
+ ========================================================================== */
1603
+ .dds-popover {
1604
+ /* Reset browser popover defaults */
1605
+ margin: 0;
1606
+ padding: 0;
1607
+ border: none;
1608
+ overflow: visible;
1609
+ inset: unset; /* we set top/left via JS */
1610
+
1611
+ /* Layout */
1612
+ position: fixed;
1613
+ width: var(--dds-popover-width-md);
1614
+ max-width: calc(100vw - 16px);
1615
+
1616
+ /* Appearance */
1617
+ background: var(--dds-popover-bg);
1618
+ border: 1px solid var(--dds-popover-border);
1619
+ border-radius: var(--dds-popover-radius);
1620
+ box-shadow: var(--dds-popover-shadow);
1621
+ color: var(--dds-popover-text);
1622
+ font-size: var(--dds-popover-text-size);
1623
+ line-height: var(--dds-line-height-relaxed);
1624
+
1625
+ /* Hidden by default (Popover API manages this, but we set it for fallback) */
1626
+ display: none;
1627
+ }
1628
+ /* Popover API open state */
1629
+ .dds-popover:popover-open {
1630
+ display: block;
1631
+ }
1632
+ /* ==========================================================================
1633
+ Entry / exit animations
1634
+ ========================================================================== */
1635
+ @keyframes dds-popover-in-bottom {
1636
+ from {
1637
+ opacity: 0;
1638
+ transform: translateY(-6px);
1639
+ }
1640
+ to {
1641
+ opacity: 1;
1642
+ transform: translateY(0);
1643
+ }
1644
+ }
1645
+ @keyframes dds-popover-in-top {
1646
+ from {
1647
+ opacity: 0;
1648
+ transform: translateY(6px);
1649
+ }
1650
+ to {
1651
+ opacity: 1;
1652
+ transform: translateY(0);
1653
+ }
1654
+ }
1655
+ .dds-popover:popover-open {
1656
+ animation: dds-popover-in-bottom 150ms ease forwards;
1657
+ }
1658
+ .dds-popover:popover-open[data-placement="top"] {
1659
+ animation: dds-popover-in-top 150ms ease forwards;
1660
+ }
1661
+ /* @starting-style enables the entry animation when the element first enters the top layer */
1662
+ @starting-style {
1663
+ .dds-popover:popover-open {
1664
+ opacity: 0;
1665
+ transform: translateY(-6px);
1666
+ }
1667
+
1668
+ .dds-popover:popover-open[data-placement="top"] {
1669
+ opacity: 0;
1670
+ transform: translateY(6px);
1671
+ }
1672
+ }
1673
+ /* ==========================================================================
1674
+ Size variants
1675
+ ========================================================================== */
1676
+ .dds-popover-sm {
1677
+ width: var(--dds-popover-width-sm);
1678
+ }
1679
+ .dds-popover-md {
1680
+ width: var(--dds-popover-width-md);
1681
+ }
1682
+ .dds-popover-lg {
1683
+ width: var(--dds-popover-width-lg);
1684
+ }
1685
+ /* ==========================================================================
1686
+ Shared inner elements
1687
+ ========================================================================== */
1688
+ .dds-popover-eyebrow {
1689
+ display: block;
1690
+ font-size: var(--dds-popover-eyebrow-size);
1691
+ font-weight: var(--dds-font-semibold);
1692
+ letter-spacing: 0.08em;
1693
+ text-transform: uppercase;
1694
+ color: var(--dds-popover-eyebrow-color);
1695
+ margin-bottom: 0.25rem;
1696
+ }
1697
+ .dds-popover-title {
1698
+ margin: 0 0 0.5rem;
1699
+ font-size: var(--dds-popover-title-size);
1700
+ font-weight: var(--dds-font-semibold);
1701
+ color: var(--dds-popover-title-color);
1702
+ line-height: var(--dds-line-height-tight);
1703
+ }
1704
+ .dds-popover-title dfn {
1705
+ font-style: normal;
1706
+ }
1707
+ .dds-popover-body {
1708
+ color: var(--dds-popover-text);
1709
+ font-size: var(--dds-popover-text-size);
1710
+ line-height: var(--dds-line-height-relaxed);
1711
+ }
1712
+ .dds-popover-body p {
1713
+ margin: 0;
1714
+ }
1715
+ .dds-popover-body a {
1716
+ color: var(--dds-popover-link-color);
1717
+ }
1718
+ .dds-popover-body a:hover {
1719
+ color: var(--dds-popover-link-color-hover);
1720
+ }
1721
+ /* ==========================================================================
1722
+ Glossary template
1723
+ ========================================================================== */
1724
+ .dds-popover-glossary {
1725
+ padding: var(--dds-popover-padding);
1726
+ }
1727
+ /* ==========================================================================
1728
+ Preview template
1729
+ ========================================================================== */
1730
+ .dds-popover-preview {
1731
+ /* no padding at top — image goes edge-to-edge */
1732
+ }
1733
+ .dds-popover-preview-image-wrap {
1734
+ width: 100%;
1735
+ height: var(--dds-popover-image-height);
1736
+ overflow: hidden;
1737
+ border-radius: var(--dds-popover-radius) var(--dds-popover-radius) 0 0;
1738
+ background: var(--dds-popover-border);
1739
+ }
1740
+ .dds-popover-preview-image {
1741
+ width: 100%;
1742
+ height: 100%;
1743
+ object-fit: cover;
1744
+ display: block;
1745
+ }
1746
+ .dds-popover-preview-body {
1747
+ padding: var(--dds-popover-padding);
1748
+ }
1749
+ .dds-popover-preview-link {
1750
+ display: inline-block;
1751
+ margin-top: 0.5rem;
1752
+ font-size: var(--dds-popover-text-size);
1753
+ font-weight: var(--dds-font-medium);
1754
+ color: var(--dds-popover-link-color);
1755
+ text-decoration: none;
1756
+ }
1757
+ .dds-popover-preview-link:hover {
1758
+ color: var(--dds-popover-link-color-hover);
1759
+ text-decoration: underline;
1760
+ }
1761
+ /* ==========================================================================
1762
+ Mobile — bottom sheet on small screens
1763
+ At ≤ 640px the popover slides up from the bottom of the viewport
1764
+ regardless of JS-computed position.
1765
+ ========================================================================== */
1766
+ @media (max-width: 640px) {
1767
+ .dds-popover:popover-open {
1768
+ /* Override JS-set position — anchor to bottom of viewport */
1769
+ top: auto !important;
1770
+ left: 0 !important;
1771
+ bottom: 0;
1772
+ width: 100% !important;
1773
+ max-width: 100%;
1774
+ border-radius: var(--dds-popover-radius) var(--dds-popover-radius) 0 0;
1775
+ border-left: none;
1776
+ border-right: none;
1777
+ border-bottom: none;
1778
+ animation: dds-popover-sheet-in 200ms ease forwards;
1779
+ }
1780
+
1781
+ .dds-popover-preview-image-wrap {
1782
+ border-radius: var(--dds-popover-radius) var(--dds-popover-radius) 0 0;
1783
+ }
1784
+ }
1785
+ @keyframes dds-popover-sheet-in {
1786
+ from {
1787
+ opacity: 0;
1788
+ transform: translateY(100%);
1789
+ }
1790
+ to {
1791
+ opacity: 1;
1792
+ transform: translateY(0);
1793
+ }
1794
+ }
1795
+ @starting-style {
1796
+ @media (max-width: 640px) {
1797
+ .dds-popover:popover-open {
1798
+ opacity: 0;
1799
+ transform: translateY(100%);
1800
+ }
1801
+ }
1802
+ }
1412
1803
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@roadlittledawn/docs-design-system-react",
3
- "version": "0.4.0",
3
+ "version": "0.6.0",
4
4
  "license": "MIT",
5
5
  "description": "React components for documentation design system",
6
6
  "repository": {