@rogieking/figui3 1.0.67 → 1.0.68

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 +40 -1
  2. package/fig.css +98 -45
  3. package/fig.js +33 -12
  4. package/package.json +1 -1
package/example.html CHANGED
@@ -17,6 +17,11 @@
17
17
  <h3>UI3 Components</h3>
18
18
  </fig-header>
19
19
  <br />
20
+ <details>
21
+ <summary>Details</summary>
22
+ <p>Some more content here</p>
23
+ </details>
24
+ <br />
20
25
  <fig-field direction="horizontal">
21
26
  <label>Opacity</label>
22
27
  <fig-slider type="opacity"
@@ -99,7 +104,11 @@
99
104
  src="https://avatars.githubusercontent.com/u/12345678?v=4"
100
105
  name="John Doe"></fig-avatar>
101
106
  <fig-avatar name="John Doe"></fig-avatar>
107
+ <fig-avatar size="large"
108
+ src=""
109
+ name="Rogie King"></fig-avatar>
102
110
  <fig-content>
111
+
103
112
  <fig-tabs>
104
113
  <fig-tab selected>Tab #1</fig-tab>
105
114
  <fig-tab>Tab #2</fig-tab>
@@ -124,6 +133,36 @@
124
133
  <fig-button>Primary</fig-button>
125
134
  <fig-button variant="secondary">Secondary</fig-button>
126
135
  <fig-button variant="ghost">Ghost</fig-button>
136
+ <fig-dialog open="true"
137
+ position="bottom right">
138
+ <fig-header>
139
+ <h3>Dialog</h3>
140
+ <fig-button variant="ghost"
141
+ icon="true"
142
+ close-dialog>
143
+ <svg width="24"
144
+ height="24"
145
+ viewBox="0 0 24 24"
146
+ fill="none"
147
+ xmlns="http://www.w3.org/2000/svg">
148
+ <path fill-rule="evenodd"
149
+ clip-rule="evenodd"
150
+ 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"
151
+ fill="currentColor"
152
+ fill-opacity="0.9" />
153
+ </svg>
154
+
155
+ </fig-button>
156
+ </fig-header>
157
+ <fig-content>
158
+ <p>Some content here</p>
159
+ </fig-content>
160
+ <footer>
161
+ <fig-button variant="secondary"
162
+ close-dialog>Cancel</fig-button>
163
+ <fig-button>Save</fig-button>
164
+ </footer>
165
+ </fig-dialog>
127
166
 
128
167
  <fig-button-combo>
129
168
  <fig-button>Primary</fig-button>
@@ -272,7 +311,7 @@
272
311
  value="#00FF00"></fig-chit>
273
312
  <fig-chit type="color"
274
313
  disabled="true"
275
- value="#FF0000"></fig-chit>
314
+ value="#000000"></fig-chit>
276
315
  <fig-chit type="gradient"
277
316
  variant="linear"
278
317
  size="large"
package/fig.css CHANGED
@@ -418,6 +418,8 @@
418
418
  --elevation-500-modal-window: 0px 0px 0.5px rgba(0, 0, 0, 0.08),
419
419
  0px 10px 24px rgba(0, 0, 0, 0.18), 0px 2px 5px rgba(0, 0, 0, 0.15);
420
420
 
421
+ --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);
422
+
421
423
  color-scheme: light dark;
422
424
  /* Icons */
423
425
  --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 +439,7 @@
437
439
  0px 0px 0.5px 0px rgba(255, 255, 255, 0.1);
438
440
  --figma-color-bg-ghost-hover: rgba(255, 255, 255, 0.05);
439
441
  --figma-color-bordertranslucent: rgba(255, 255, 255, 0.1);
440
- --elevation-500-modal-window: 0px 10px 24px rgba(0, 0, 0, 0.45),
442
+ --figma-elevation-500-modal-window: 0px 10px 24px rgba(0, 0, 0, 0.45),
441
443
  0px 3px 5px rgba(0, 0, 0, 0.35),
442
444
  inset 0px 0.75px 0px rgba(255, 255, 255, 0.1);
443
445
  --figma-elevation-100: 0px 0px 0.5px 0px rgba(0, 0, 0, 0.5),
@@ -446,6 +448,7 @@
446
448
  }
447
449
  }
448
450
 
451
+
449
452
  html {
450
453
  width: 100%;
451
454
  height: 100%;
@@ -860,15 +863,19 @@ fig-avatar,
860
863
  background: var(--figma-color-bg-brand);
861
864
  overflow: hidden;
862
865
  color: var(--figma-color-icon-onbrand);
863
- box-shadow: inset 0 0 0 1px var(--figma-color-bordertranslucent);
864
866
 
865
867
  img {
866
868
  width: var(--size);
867
869
  height: var(--size);
868
870
  position: absolute;
869
- background: var(--checkerboard);
870
871
  border-radius: 100%;
871
872
  box-shadow: inset 0 0 0 1px var(--figma-color-bordertranslucent);
873
+ &:not([src]) {
874
+ background: var(--checkerboard);
875
+ }
876
+ }
877
+ &[borderless] {
878
+ box-shadow: none;
872
879
  }
873
880
 
874
881
  &:has(img[src]) {
@@ -902,40 +909,43 @@ input[type="color"] {
902
909
  box-shadow: inset 0 0 0 1px var(--figma-color-border-selected);
903
910
  outline: 0;
904
911
  }
905
- }
906
912
 
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
- }
913
+ &::-webkit-color-swatch-wrapper {
914
+ padding: 0;
915
+ border: 0;
916
+ border-radius: 0.125rem;
917
+ background: var(--checkerboard);
918
+ overflow: hidden;
919
+ outline: 1px solid var(--figma-color-bordertranslucent);
920
+ outline-offset: -1px;
921
+ }
915
922
 
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
- }
923
+ &::-moz-color-swatch {
924
+ border-radius: 0.125rem;
925
+ padding: 0;
926
+ border: 0;
927
+ mask-image: linear-gradient(
928
+ to right,
929
+ black 0%,
930
+ black 50%,
931
+ rgba(0, 0, 0, var(--alpha)) 50%
932
+ );
933
+ box-shadow: inset 0 0 0 1px var(--figma-color-bordertranslucent);
934
+ }
927
935
 
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
- );
936
+ &::-webkit-color-swatch {
937
+ padding: 0;
938
+ border: 0;
939
+ mask-image: linear-gradient(
940
+ to right,
941
+ black 0%,
942
+ black 50%,
943
+ rgba(0, 0, 0, var(--alpha)) 50%
944
+ );
945
+ }
937
946
  }
938
947
 
948
+
939
949
  fig-chit {
940
950
  --gradient-color-1: #ff90ff;
941
951
  --gradient-color-2: #0000ff;
@@ -1718,7 +1728,17 @@ dialog,
1718
1728
  background: var(--figma-color-bg);
1719
1729
  min-width: var(--popover-min-width);
1720
1730
 
1721
- box-shadow: var(--figma-elevation-100);
1731
+ box-shadow: var(--figma-elevation-500-modal-window);
1732
+
1733
+ footer {
1734
+ display: flex;
1735
+ justify-content: flex-end;
1736
+ padding: var(--spacer-2);
1737
+ gap: var(--spacer-2);
1738
+ }
1739
+ p {
1740
+ padding: 0 var(--spacer-3);
1741
+ }
1722
1742
 
1723
1743
  &:popover-open {
1724
1744
  display: block;
@@ -1781,25 +1801,59 @@ dialog,
1781
1801
  }
1782
1802
  }
1783
1803
  }
1804
+ fig-dialog,
1805
+ .fig-dialog {
1806
+ display: contents;
1807
+ --offset: 1rem;
1808
+ --translate-x: -50%;
1809
+ --translate-y: -50%;
1784
1810
 
1785
- dialog {
1786
- position: fixed;
1787
- top: 50%;
1788
- left: 50%;
1789
- margin: 0;
1790
- transform: translate(-50%, -50%);
1811
+ dialog {
1812
+ position: fixed;
1813
+ top: 50%;
1814
+ left: 50%;
1815
+ margin: 0;
1816
+ z-index: 999999;
1817
+ transform: translate(var(--translate-x), var(--translate-y));
1818
+ }
1791
1819
 
1792
1820
  &[position*="bottom"] {
1793
- bottom: 0.5rem;
1794
- top: auto;
1795
- transform: translate(-50%, 0);
1821
+ dialog {
1822
+ bottom: var(--offset);
1823
+ top: auto;
1824
+ --translate-y: 0;
1825
+ }
1826
+ }
1827
+ &[position*="top"] {
1828
+ dialog {
1829
+ top: var(--offset);
1830
+ bottom: auto;
1831
+ --translate-y: 0;
1832
+ }
1833
+ }
1834
+ &[position*="right"] {
1835
+ dialog {
1836
+ right: var(--offset);
1837
+ left: auto;
1838
+ --translate-x: 0;
1839
+ }
1840
+ }
1841
+ &[position*="left"] {
1842
+ dialog {
1843
+ left: var(--offset);
1844
+ right: auto;
1845
+ --translate-: 0;
1846
+ }
1796
1847
  }
1797
1848
  }
1798
1849
 
1799
1850
  /* Tooltip */
1851
+ fig-tooltip{
1852
+ display: contents;
1853
+ }
1800
1854
  .fig-tooltip {
1801
1855
  inset: unset;
1802
- display: contents;
1856
+ display: block;
1803
1857
  color: var(--color-tooltip);
1804
1858
  background-color: var(--bg-tooltip);
1805
1859
  padding: var(--spacer-1) var(--spacer-2);
@@ -1882,7 +1936,6 @@ fig-icon.close {
1882
1936
  /* Web Components */
1883
1937
  fig-button,
1884
1938
  fig-popover,
1885
- fig-dialog,
1886
1939
  fig-content,
1887
1940
  fig-slider,
1888
1941
  fig-switch,
@@ -1949,7 +2002,7 @@ fig-header {
1949
2002
  gap: 0.25rem;
1950
2003
 
1951
2004
  & h3 {
1952
- padding-left: var(--spacer-1);
2005
+ padding-left: var(--spacer-2);
1953
2006
  font-weight: var(--body-medium-strong-fontWeight);
1954
2007
  flex-grow: 1;
1955
2008
  }
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.68"
4
4
  }