@rogieking/figui3 1.0.67 → 1.0.69

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 (4) hide show
  1. package/example.html +42 -1
  2. package/fig.css +114 -46
  3. package/fig.js +33 -12
  4. package/package.json +1 -1
package/example.html CHANGED
@@ -16,6 +16,13 @@
16
16
  <fig-header>
17
17
  <h3>UI3 Components</h3>
18
18
  </fig-header>
19
+ <h2>Heading 2</h2>
20
+ <h3>Heading 3</h3>
21
+ <br />
22
+ <details>
23
+ <summary>Details</summary>
24
+ <p>Some more content here</p>
25
+ </details>
19
26
  <br />
20
27
  <fig-field direction="horizontal">
21
28
  <label>Opacity</label>
@@ -99,7 +106,11 @@
99
106
  src="https://avatars.githubusercontent.com/u/12345678?v=4"
100
107
  name="John Doe"></fig-avatar>
101
108
  <fig-avatar name="John Doe"></fig-avatar>
109
+ <fig-avatar size="large"
110
+ src=""
111
+ name="Rogie King"></fig-avatar>
102
112
  <fig-content>
113
+
103
114
  <fig-tabs>
104
115
  <fig-tab selected>Tab #1</fig-tab>
105
116
  <fig-tab>Tab #2</fig-tab>
@@ -124,6 +135,36 @@
124
135
  <fig-button>Primary</fig-button>
125
136
  <fig-button variant="secondary">Secondary</fig-button>
126
137
  <fig-button variant="ghost">Ghost</fig-button>
138
+ <fig-dialog open="true"
139
+ position="bottom right">
140
+ <fig-header>
141
+ <h3>Dialog</h3>
142
+ <fig-button variant="ghost"
143
+ icon="true"
144
+ close-dialog>
145
+ <svg width="24"
146
+ height="24"
147
+ viewBox="0 0 24 24"
148
+ fill="none"
149
+ xmlns="http://www.w3.org/2000/svg">
150
+ <path fill-rule="evenodd"
151
+ clip-rule="evenodd"
152
+ d="M17.3536 6.64645C17.5488 6.84171 17.5488 7.15829 17.3536 7.35355L12.7071 12L17.3536 16.6464C17.5488 16.8417 17.5488 17.1583 17.3536 17.3536C17.1583 17.5488 16.8417 17.5488 16.6464 17.3536L12 12.7071L7.35355 17.3536C7.15829 17.5488 6.84171 17.5488 6.64645 17.3536C6.45118 17.1583 6.45118 16.8417 6.64645 16.6464L11.2929 12L6.64645 7.35365C6.45119 7.15839 6.45118 6.84181 6.64644 6.64654C6.84171 6.45128 7.15829 6.45128 7.35355 6.64654L12 11.2929L16.6464 6.64645C16.8417 6.45118 17.1583 6.45118 17.3536 6.64645Z"
153
+ fill="currentColor"
154
+ fill-opacity="0.9" />
155
+ </svg>
156
+
157
+ </fig-button>
158
+ </fig-header>
159
+ <fig-content>
160
+ <p>Some content here</p>
161
+ </fig-content>
162
+ <footer>
163
+ <fig-button variant="secondary"
164
+ close-dialog>Cancel</fig-button>
165
+ <fig-button>Save</fig-button>
166
+ </footer>
167
+ </fig-dialog>
127
168
 
128
169
  <fig-button-combo>
129
170
  <fig-button>Primary</fig-button>
@@ -272,7 +313,7 @@
272
313
  value="#00FF00"></fig-chit>
273
314
  <fig-chit type="color"
274
315
  disabled="true"
275
- value="#FF0000"></fig-chit>
316
+ value="#000000"></fig-chit>
276
317
  <fig-chit type="gradient"
277
318
  variant="linear"
278
319
  size="large"
package/fig.css CHANGED
@@ -398,6 +398,7 @@
398
398
  --bg-selected-active: #e5f4ff;
399
399
  --bg-tooltip: #1e1e1e;
400
400
  --body-medium-fontSize: 0.6875rem;
401
+ --body-large-fontSize: 0.8125rem;
401
402
  --figma-color-border-selected: #0d99ff;
402
403
  --spacer-1: 0.25rem;
403
404
  --spacer-2: 0.5rem;
@@ -408,7 +409,10 @@
408
409
  --color-tooltip: #ffffff;
409
410
  --radius-medium: 0.3125rem;
410
411
  --radius-large: 0.8125rem;
412
+ --body-letter-spacing: 0.055px;
411
413
  --body-medium-strong-fontWeight: 550;
414
+ --body-large-strong-fontWeight: 500;
415
+ --body-medium-fontWeight: 450;
412
416
  --handle-shadow: 0px 0 0 0.75px rgba(0, 0, 0, 0.1),
413
417
  0px 1px 3px 0px rgba(0, 0, 0, 0.05), 0px 3px 8px 0px rgba(0, 0, 0, 0.05),
414
418
  0px 0px 0.5px 0px rgba(0, 0, 0, 0.1);
@@ -418,6 +422,8 @@
418
422
  --elevation-500-modal-window: 0px 0px 0.5px rgba(0, 0, 0, 0.08),
419
423
  0px 10px 24px rgba(0, 0, 0, 0.18), 0px 2px 5px rgba(0, 0, 0, 0.15);
420
424
 
425
+ --figma-elevation-500-modal-window: box-shadow: 0px 0px 0.5px 0px rgba(0, 0, 0, 0.08), 0px 10px 24px 0px rgba(0, 0, 0, 0.18), 0px 2px 5px 0px rgba(0, 0, 0, 0.15);
426
+
421
427
  color-scheme: light dark;
422
428
  /* Icons */
423
429
  --icon-chevron: url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5.87868 7.12132L8 9.24264L10.1213 7.12132' stroke='rgb(0 0 0 / 90%)' stroke-linecap='round'/%3E%3C/svg%3E%0A");
@@ -437,7 +443,7 @@
437
443
  0px 0px 0.5px 0px rgba(255, 255, 255, 0.1);
438
444
  --figma-color-bg-ghost-hover: rgba(255, 255, 255, 0.05);
439
445
  --figma-color-bordertranslucent: rgba(255, 255, 255, 0.1);
440
- --elevation-500-modal-window: 0px 10px 24px rgba(0, 0, 0, 0.45),
446
+ --figma-elevation-500-modal-window: 0px 10px 24px rgba(0, 0, 0, 0.45),
441
447
  0px 3px 5px rgba(0, 0, 0, 0.35),
442
448
  inset 0px 0.75px 0px rgba(255, 255, 255, 0.1);
443
449
  --figma-elevation-100: 0px 0px 0.5px 0px rgba(0, 0, 0, 0.5),
@@ -446,6 +452,7 @@
446
452
  }
447
453
  }
448
454
 
455
+
449
456
  html {
450
457
  width: 100%;
451
458
  height: 100%;
@@ -458,7 +465,8 @@ html {
458
465
  segoe ui, helvetica neue, helvetica, Cantarell, Ubuntu, roboto, noto, arial,
459
466
  sans-serif;
460
467
  font-size: 16px;
461
- font-weight: 500;
468
+ font-weight: var(--body-medium-fontWeight);
469
+ letter-spacing: var(--body-letter-spacing);
462
470
  background-color: var(--figma-color-bg);
463
471
  }
464
472
 
@@ -470,6 +478,16 @@ html {
470
478
 
471
479
  body {
472
480
  font-size: var(--body-medium-fontSize);
481
+ letter-spacing: var(--body-letter-spacing);
482
+ }
483
+
484
+ h1,h2{
485
+ font-weight: var(--body-large-strong-fontWeight);
486
+ font-size: var(--body-large-fontSize);
487
+ }
488
+ h3{
489
+ font-weight: var(--body-medium-strong-fontWeight);
490
+ font-size: var(--body-medium-fontSize);
473
491
  }
474
492
 
475
493
  /* helper classes/defaults */
@@ -860,15 +878,19 @@ fig-avatar,
860
878
  background: var(--figma-color-bg-brand);
861
879
  overflow: hidden;
862
880
  color: var(--figma-color-icon-onbrand);
863
- box-shadow: inset 0 0 0 1px var(--figma-color-bordertranslucent);
864
881
 
865
882
  img {
866
883
  width: var(--size);
867
884
  height: var(--size);
868
885
  position: absolute;
869
- background: var(--checkerboard);
870
886
  border-radius: 100%;
871
887
  box-shadow: inset 0 0 0 1px var(--figma-color-bordertranslucent);
888
+ &:not([src]) {
889
+ background: var(--checkerboard);
890
+ }
891
+ }
892
+ &[borderless] {
893
+ box-shadow: none;
872
894
  }
873
895
 
874
896
  &:has(img[src]) {
@@ -902,40 +924,43 @@ input[type="color"] {
902
924
  box-shadow: inset 0 0 0 1px var(--figma-color-border-selected);
903
925
  outline: 0;
904
926
  }
905
- }
906
927
 
907
- input[type="color"]::-webkit-color-swatch-wrapper {
908
- padding: 0;
909
- border: 0;
910
- border-radius: 0.125rem;
911
- background: var(--checkerboard);
912
- overflow: hidden;
913
- box-shadow: inset 0 0 0 1px var(--figma-color-bordertranslucent);
914
- }
928
+ &::-webkit-color-swatch-wrapper {
929
+ padding: 0;
930
+ border: 0;
931
+ border-radius: 0.125rem;
932
+ background: var(--checkerboard);
933
+ overflow: hidden;
934
+ outline: 1px solid var(--figma-color-bordertranslucent);
935
+ outline-offset: -1px;
936
+ }
915
937
 
916
- input[type="color"]::-moz-color-swatch {
917
- border-radius: 0.125rem;
918
- padding: 0;
919
- border: 0;
920
- mask-image: linear-gradient(
921
- to right,
922
- black 0%,
923
- black 50%,
924
- rgba(0, 0, 0, var(--alpha)) 50%
925
- );
926
- }
938
+ &::-moz-color-swatch {
939
+ border-radius: 0.125rem;
940
+ padding: 0;
941
+ border: 0;
942
+ mask-image: linear-gradient(
943
+ to right,
944
+ black 0%,
945
+ black 50%,
946
+ rgba(0, 0, 0, var(--alpha)) 50%
947
+ );
948
+ box-shadow: inset 0 0 0 1px var(--figma-color-bordertranslucent);
949
+ }
927
950
 
928
- input[type="color"]::-webkit-color-swatch {
929
- padding: 0;
930
- border: 0;
931
- mask-image: linear-gradient(
932
- to right,
933
- black 0%,
934
- black 50%,
935
- rgba(0, 0, 0, var(--alpha)) 50%
936
- );
951
+ &::-webkit-color-swatch {
952
+ padding: 0;
953
+ border: 0;
954
+ mask-image: linear-gradient(
955
+ to right,
956
+ black 0%,
957
+ black 50%,
958
+ rgba(0, 0, 0, var(--alpha)) 50%
959
+ );
960
+ }
937
961
  }
938
962
 
963
+
939
964
  fig-chit {
940
965
  --gradient-color-1: #ff90ff;
941
966
  --gradient-color-2: #0000ff;
@@ -1718,7 +1743,17 @@ dialog,
1718
1743
  background: var(--figma-color-bg);
1719
1744
  min-width: var(--popover-min-width);
1720
1745
 
1721
- box-shadow: var(--figma-elevation-100);
1746
+ box-shadow: var(--figma-elevation-500-modal-window);
1747
+
1748
+ footer {
1749
+ display: flex;
1750
+ justify-content: flex-end;
1751
+ padding: var(--spacer-2);
1752
+ gap: var(--spacer-2);
1753
+ }
1754
+ p {
1755
+ padding: 0 var(--spacer-3);
1756
+ }
1722
1757
 
1723
1758
  &:popover-open {
1724
1759
  display: block;
@@ -1781,25 +1816,59 @@ dialog,
1781
1816
  }
1782
1817
  }
1783
1818
  }
1819
+ fig-dialog,
1820
+ .fig-dialog {
1821
+ display: contents;
1822
+ --offset: 1rem;
1823
+ --translate-x: -50%;
1824
+ --translate-y: -50%;
1784
1825
 
1785
- dialog {
1786
- position: fixed;
1787
- top: 50%;
1788
- left: 50%;
1789
- margin: 0;
1790
- transform: translate(-50%, -50%);
1826
+ dialog {
1827
+ position: fixed;
1828
+ top: 50%;
1829
+ left: 50%;
1830
+ margin: 0;
1831
+ z-index: 999999;
1832
+ transform: translate(var(--translate-x), var(--translate-y));
1833
+ }
1791
1834
 
1792
1835
  &[position*="bottom"] {
1793
- bottom: 0.5rem;
1794
- top: auto;
1795
- transform: translate(-50%, 0);
1836
+ dialog {
1837
+ bottom: var(--offset);
1838
+ top: auto;
1839
+ --translate-y: 0;
1840
+ }
1841
+ }
1842
+ &[position*="top"] {
1843
+ dialog {
1844
+ top: var(--offset);
1845
+ bottom: auto;
1846
+ --translate-y: 0;
1847
+ }
1848
+ }
1849
+ &[position*="right"] {
1850
+ dialog {
1851
+ right: var(--offset);
1852
+ left: auto;
1853
+ --translate-x: 0;
1854
+ }
1855
+ }
1856
+ &[position*="left"] {
1857
+ dialog {
1858
+ left: var(--offset);
1859
+ right: auto;
1860
+ --translate-: 0;
1861
+ }
1796
1862
  }
1797
1863
  }
1798
1864
 
1799
1865
  /* Tooltip */
1866
+ fig-tooltip{
1867
+ display: contents;
1868
+ }
1800
1869
  .fig-tooltip {
1801
1870
  inset: unset;
1802
- display: contents;
1871
+ display: block;
1803
1872
  color: var(--color-tooltip);
1804
1873
  background-color: var(--bg-tooltip);
1805
1874
  padding: var(--spacer-1) var(--spacer-2);
@@ -1882,7 +1951,6 @@ fig-icon.close {
1882
1951
  /* Web Components */
1883
1952
  fig-button,
1884
1953
  fig-popover,
1885
- fig-dialog,
1886
1954
  fig-content,
1887
1955
  fig-slider,
1888
1956
  fig-switch,
@@ -1949,7 +2017,7 @@ fig-header {
1949
2017
  gap: 0.25rem;
1950
2018
 
1951
2019
  & h3 {
1952
- padding-left: var(--spacer-1);
2020
+ padding-left: var(--spacer-2);
1953
2021
  font-weight: var(--body-medium-strong-fontWeight);
1954
2022
  flex-grow: 1;
1955
2023
  }
package/fig.js CHANGED
@@ -209,6 +209,7 @@ class FigTooltip extends HTMLElement {
209
209
  this.popup.setAttribute("class", "fig-tooltip");
210
210
  this.popup.style.position = "fixed";
211
211
  this.popup.style.visibility = "hidden";
212
+ this.popup.style.display = "inline-flex";
212
213
  this.popup.style.pointerEvents = "none";
213
214
  this.popup.innerText = this.getAttribute("text");
214
215
  document.body.append(this.popup);
@@ -216,7 +217,7 @@ class FigTooltip extends HTMLElement {
216
217
 
217
218
  destroy() {
218
219
  if (this.popup) {
219
- this.popup.remove();
220
+ //this.popup.remove();
220
221
  }
221
222
  document.body.addEventListener("click", this.hidePopupOutsideClick);
222
223
  }
@@ -255,7 +256,7 @@ class FigTooltip extends HTMLElement {
255
256
  }
256
257
 
257
258
  showPopup() {
258
- const rect = this.getBoundingClientRect();
259
+ const rect = this.firstElementChild.getBoundingClientRect();
259
260
  const popupRect = this.popup.getBoundingClientRect();
260
261
  const offset = this.getOffset();
261
262
 
@@ -339,17 +340,28 @@ class FigDialog extends HTMLElement {
339
340
  }
340
341
 
341
342
  connectedCallback() {
342
- this.render();
343
+ this.modal =
344
+ this.hasAttribute("modal") && this.getAttribute("modal") !== "false";
345
+ this.appendChild(this.dialog);
346
+ this.shadowRoot.appendChild(this.contentSlot);
347
+ this.contentSlot.addEventListener("slotchange", this.slotChange.bind(this));
348
+
349
+ requestAnimationFrame(() => {
350
+ this.#addCloseListeners();
351
+ });
343
352
  }
344
353
 
345
- disconnectedCallback() {
346
- this.contentSlot.removeEventListener("slotchange", this.slotChange);
354
+ #addCloseListeners() {
355
+ this.dialog
356
+ .querySelectorAll("fig-button[close-dialog]")
357
+ .forEach((button) => {
358
+ button.removeEventListener("click", this.close);
359
+ button.addEventListener("click", this.close.bind(this));
360
+ });
347
361
  }
348
362
 
349
- render() {
350
- this.appendChild(this.dialog);
351
- this.shadowRoot.appendChild(this.contentSlot);
352
- this.contentSlot.addEventListener("slotchange", this.slotChange.bind(this));
363
+ disconnectedCallback() {
364
+ this.contentSlot.removeEventListener("slotchange", this.slotChange);
353
365
  }
354
366
 
355
367
  slotChange() {
@@ -361,25 +373,34 @@ class FigDialog extends HTMLElement {
361
373
  this.dialog.appendChild(node.cloneNode(true));
362
374
  }
363
375
  });
376
+ this.#addCloseListeners();
364
377
  }
365
378
 
366
379
  static get observedAttributes() {
367
- return ["open"];
380
+ return ["open", "modal"];
368
381
  }
369
382
 
370
383
  attributeChangedCallback(name, oldValue, newValue) {
371
384
  switch (name) {
372
385
  case "open":
386
+ this.open = newValue === "true" && newValue !== "false";
373
387
  if (this?.show) {
374
- this[newValue === "true" ? "show" : "close"]();
388
+ this[this.open ? "show" : "close"]();
375
389
  }
376
390
  break;
391
+ case "modal":
392
+ this.modal = newValue === "true" && newValue !== "false";
393
+ break;
377
394
  }
378
395
  }
379
396
 
380
397
  /* Public methods */
381
398
  show() {
382
- this.dialog.show();
399
+ if (this.modal) {
400
+ this.dialog.showModal();
401
+ } else {
402
+ this.dialog.show();
403
+ }
383
404
  }
384
405
  close() {
385
406
  this.dialog.close();
package/package.json CHANGED
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "name": "@rogieking/figui3",
3
- "version": "1.0.67"
3
+ "version": "1.0.69"
4
4
  }