@uzum-tech/ui 2.0.0-beta.9 → 2.0.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.
Files changed (36) hide show
  1. package/dist/index.js +240 -197
  2. package/dist/index.mjs +240 -197
  3. package/dist/index.prod.js +2 -2
  4. package/dist/index.prod.mjs +2 -2
  5. package/es/_internal/icon/index.d.ts +2 -0
  6. package/es/_internal/icon/index.mjs +2 -1
  7. package/es/_internal/icon/src/UIcon.d.ts +126 -0
  8. package/es/_internal/icon/src/UIcon.mjs +131 -0
  9. package/es/_mixins/use-config.d.ts +2 -1
  10. package/es/_mixins/use-config.mjs +1 -0
  11. package/es/components.d.ts +113 -34
  12. package/es/config-provider/src/ConfigProvider.d.ts +4 -1
  13. package/es/config-provider/src/ConfigProvider.mjs +8 -0
  14. package/es/config-provider/src/interface.d.ts +1 -1
  15. package/es/config-provider/src/internal-interface.d.ts +8 -0
  16. package/es/icon/src/Icon.d.ts +2 -109
  17. package/es/icon/src/Icon.mjs +1 -93
  18. package/es/version.d.ts +1 -1
  19. package/es/version.mjs +1 -1
  20. package/lib/_internal/icon/index.d.ts +2 -0
  21. package/lib/_internal/icon/index.js +4 -1
  22. package/lib/_internal/icon/src/UIcon.d.ts +126 -0
  23. package/lib/_internal/icon/src/UIcon.js +108 -0
  24. package/lib/_mixins/use-config.d.ts +2 -1
  25. package/lib/_mixins/use-config.js +1 -0
  26. package/lib/components.d.ts +113 -34
  27. package/lib/config-provider/src/ConfigProvider.d.ts +4 -1
  28. package/lib/config-provider/src/ConfigProvider.js +8 -0
  29. package/lib/config-provider/src/interface.d.ts +1 -1
  30. package/lib/config-provider/src/internal-interface.d.ts +8 -0
  31. package/lib/icon/src/Icon.d.ts +2 -109
  32. package/lib/icon/src/Icon.js +3 -73
  33. package/lib/version.d.ts +1 -1
  34. package/lib/version.js +1 -1
  35. package/package.json +8 -1
  36. package/web-types.json +11 -1
package/dist/index.js CHANGED
@@ -5809,6 +5809,7 @@
5809
5809
  inlineThemeDisabled: UConfigProvider?.inlineThemeDisabled,
5810
5810
  mergedRtlRef: UConfigProvider?.mergedRtlRef,
5811
5811
  mergedComponentPropsRef: UConfigProvider?.mergedComponentPropsRef,
5812
+ mergedIconPacksRef: UConfigProvider?.mergedIconPacksRef,
5812
5813
  mergedBreakpointsRef: UConfigProvider?.mergedBreakpointsRef,
5813
5814
  mergedBorderedRef: vue.computed(() => {
5814
5815
  const {
@@ -13049,6 +13050,28 @@
13049
13050
  }
13050
13051
  });
13051
13052
 
13053
+ var style$1U = cB("icon", `
13054
+ height: 1em;
13055
+ width: 1em;
13056
+ line-height: 1em;
13057
+ text-align: center;
13058
+ display: inline-block;
13059
+ position: relative;
13060
+ fill: currentColor;
13061
+ transform: translateZ(0);
13062
+ `, [cM("color-transition", {
13063
+ transition: "color .3s var(--u-bezier)"
13064
+ }), cM("depth", {
13065
+ color: "var(--u-color)"
13066
+ }, [c$1("svg", {
13067
+ opacity: "var(--u-opacity)",
13068
+ transition: "opacity .3s var(--u-bezier)"
13069
+ })]), c$1("svg", {
13070
+ height: "100%",
13071
+ width: "100%",
13072
+ display: "block"
13073
+ })]);
13074
+
13052
13075
  const derived$1 = {
13053
13076
  name: "common",
13054
13077
  ...commonVariables$6,
@@ -13213,6 +13236,154 @@
13213
13236
  boxShadow2: "0px 20px 80px 0px rgba(0, 0, 0, 0.07)"
13214
13237
  };
13215
13238
 
13239
+ function self$1B(vars) {
13240
+ const {
13241
+ elementsPrimary
13242
+ } = vars;
13243
+ return {
13244
+ color: elementsPrimary,
13245
+ opacity1Depth: "0.82",
13246
+ opacity2Depth: "0.72",
13247
+ opacity3Depth: "0.38",
13248
+ opacity4Depth: "0.24",
13249
+ opacity5Depth: "0.18"
13250
+ };
13251
+ }
13252
+ const iconLight = {
13253
+ name: "Icon",
13254
+ common: derived,
13255
+ self: self$1B
13256
+ };
13257
+
13258
+ const iconDark$1 = {
13259
+ name: "Icon",
13260
+ common: derived$1,
13261
+ self: self$1B
13262
+ };
13263
+
13264
+ const iconProps = {
13265
+ ...useTheme.props,
13266
+ depth: [String, Number],
13267
+ size: [Number, String],
13268
+ color: String,
13269
+ component: Object,
13270
+ name: String,
13271
+ pack: String,
13272
+ onClick: Function
13273
+ };
13274
+ const UIconImpl = vue.defineComponent({
13275
+ _n_icon__: true,
13276
+ name: "Icon",
13277
+ props: iconProps,
13278
+ setup(props) {
13279
+ const {
13280
+ mergedClsPrefixRef,
13281
+ mergedIconPacksRef,
13282
+ inlineThemeDisabled
13283
+ } = useConfig(props);
13284
+ const themeRef = useTheme("Icon", "-icon", style$1U, iconLight, props, mergedClsPrefixRef);
13285
+ const cssVarsRef = vue.computed(() => {
13286
+ const {
13287
+ depth
13288
+ } = props;
13289
+ const {
13290
+ common: {
13291
+ cubicBezierEaseInOut
13292
+ },
13293
+ self
13294
+ } = themeRef.value;
13295
+ if (depth !== void 0) {
13296
+ const {
13297
+ color,
13298
+ [`opacity${depth}Depth`]: opacity
13299
+ } = self;
13300
+ return {
13301
+ "--u-bezier": cubicBezierEaseInOut,
13302
+ "--u-color": color,
13303
+ "--u-opacity": opacity
13304
+ };
13305
+ }
13306
+ return {
13307
+ "--u-bezier": cubicBezierEaseInOut,
13308
+ "--u-color": "",
13309
+ "--u-opacity": ""
13310
+ };
13311
+ });
13312
+ const themeClassHandle = inlineThemeDisabled ? useThemeClass("icon", vue.computed(() => `${props.depth || "d"}`), cssVarsRef, props) : void 0;
13313
+ const resolvedPackedIconRef = vue.computed(() => {
13314
+ const {
13315
+ name,
13316
+ pack
13317
+ } = props;
13318
+ if (!name) return null;
13319
+ const config = mergedIconPacksRef?.value;
13320
+ if (!config) {
13321
+ warn("icon", "no icon packs configured on `u-config-provider`");
13322
+ return null;
13323
+ }
13324
+ const targetName = pack ?? config.defaultPackName;
13325
+ const target = config.packs.find(p => p.name === targetName);
13326
+ if (!target) {
13327
+ warn("icon", `icon pack "${targetName}" not found`);
13328
+ return null;
13329
+ }
13330
+ if (config.async) {
13331
+ return target.renderAsyncIcon(name);
13332
+ }
13333
+ if (!("renderIcon" in target)) {
13334
+ warn("icon", `pack "${target.name}" is async-only, set \`async: true\` on \`u-config-provider :icon-packs\``);
13335
+ return null;
13336
+ }
13337
+ return target.renderIcon(name);
13338
+ });
13339
+ return {
13340
+ mergedClsPrefix: mergedClsPrefixRef,
13341
+ resolvedPackedIcon: resolvedPackedIconRef,
13342
+ mergedStyle: vue.computed(() => {
13343
+ const {
13344
+ size,
13345
+ color
13346
+ } = props;
13347
+ return {
13348
+ fontSize: formatLength(size),
13349
+ color
13350
+ };
13351
+ }),
13352
+ cssVars: inlineThemeDisabled ? void 0 : cssVarsRef,
13353
+ themeClass: themeClassHandle?.themeClass,
13354
+ onRender: themeClassHandle?.onRender
13355
+ };
13356
+ },
13357
+ render() {
13358
+ const {
13359
+ $parent,
13360
+ depth,
13361
+ mergedClsPrefix,
13362
+ component,
13363
+ onRender,
13364
+ themeClass,
13365
+ resolvedPackedIcon
13366
+ } = this;
13367
+ if ($parent?.$options?._n_icon__) {
13368
+ warn("icon", "don't wrap `u-icon` inside `u-icon`");
13369
+ }
13370
+ onRender?.();
13371
+ return vue.h(UBaseIcon, {
13372
+ clsPrefix: mergedClsPrefix,
13373
+ role: "img",
13374
+ class: [`${mergedClsPrefix}-icon`, themeClass, {
13375
+ [`${mergedClsPrefix}-icon--depth`]: depth,
13376
+ [`${mergedClsPrefix}-icon--color-transition`]: depth !== void 0
13377
+ }],
13378
+ style: [this.cssVars, this.mergedStyle],
13379
+ onClick: this.onClick
13380
+ }, {
13381
+ default: () => resolvedPackedIcon ?? (component ? vue.h(component) : this.$slots.default?.())
13382
+ });
13383
+ }
13384
+ });
13385
+ const UIcon$1 = UIconImpl;
13386
+
13216
13387
  var commonVars$b = {
13217
13388
  iconWidth: "44px",
13218
13389
  iconHeight: "44px",
@@ -13225,7 +13396,7 @@
13225
13396
  avatarSize: "16px"
13226
13397
  };
13227
13398
 
13228
- function self$1B(vars) {
13399
+ function self$1A(vars) {
13229
13400
  const {
13230
13401
  heightHuge,
13231
13402
  fontBodyLarge,
@@ -13255,16 +13426,16 @@
13255
13426
  const accountOptionLight = {
13256
13427
  name: "AccountOption",
13257
13428
  common: derived,
13258
- self: self$1B
13429
+ self: self$1A
13259
13430
  };
13260
13431
 
13261
13432
  const accountOptionDark = {
13262
13433
  name: "AccountOption",
13263
13434
  common: derived$1,
13264
- self: self$1B
13435
+ self: self$1A
13265
13436
  };
13266
13437
 
13267
- var style$1U = cB("base-account-option", `
13438
+ var style$1T = cB("base-account-option", `
13268
13439
  display: flex;
13269
13440
  align-items: center;
13270
13441
  position: relative;
@@ -13319,7 +13490,7 @@
13319
13490
  const themeRef = useTheme(
13320
13491
  "AccountOption",
13321
13492
  "-base-account-option",
13322
- style$1U,
13493
+ style$1T,
13323
13494
  accountOptionLight,
13324
13495
  props,
13325
13496
  mergedClsPrefixRef
@@ -14758,7 +14929,7 @@
14758
14929
  })];
14759
14930
  }
14760
14931
 
14761
- var style$1T = cB("base-clear", `
14932
+ var style$1S = cB("base-clear", `
14762
14933
  flex-shrink: 0;
14763
14934
  height: 1em;
14764
14935
  width: 1em;
@@ -14799,7 +14970,7 @@
14799
14970
  onClear: Function
14800
14971
  },
14801
14972
  setup(props) {
14802
- useStyle("-base-clear", style$1T, vue.toRef(props, "clsPrefix"));
14973
+ useStyle("-base-clear", style$1S, vue.toRef(props, "clsPrefix"));
14803
14974
  return {
14804
14975
  handleMouseDown(e) {
14805
14976
  e.preventDefault();
@@ -14830,7 +15001,7 @@
14830
15001
  }
14831
15002
  });
14832
15003
 
14833
- var style$1S = cB("base-close", `
15004
+ var style$1R = cB("base-close", `
14834
15005
  display: flex;
14835
15006
  align-items: center;
14836
15007
  justify-content: center;
@@ -14902,7 +15073,7 @@
14902
15073
  absolute: Boolean
14903
15074
  },
14904
15075
  setup(props) {
14905
- useStyle("-base-close", style$1S, vue.toRef(props, "clsPrefix"));
15076
+ useStyle("-base-close", style$1R, vue.toRef(props, "clsPrefix"));
14906
15077
  return () => {
14907
15078
  const { clsPrefix, disabled, absolute, round, isButtonTag } = props;
14908
15079
  const Tag = isButtonTag ? "button" : "div";
@@ -15061,7 +15232,7 @@
15061
15232
  }
15062
15233
  });
15063
15234
 
15064
- var style$1R = c$1([c$1("@keyframes loading-container-rotate", `
15235
+ var style$1Q = c$1([c$1("@keyframes loading-container-rotate", `
15065
15236
  to {
15066
15237
  -webkit-transform: rotate(360deg);
15067
15238
  transform: rotate(360deg);
@@ -15231,7 +15402,7 @@
15231
15402
  ...exposedLoadingProps
15232
15403
  },
15233
15404
  setup(props) {
15234
- useStyle("-base-loading", style$1R, vue.toRef(props, "clsPrefix"));
15405
+ useStyle("-base-loading", style$1Q, vue.toRef(props, "clsPrefix"));
15235
15406
  },
15236
15407
  render() {
15237
15408
  const { clsPrefix, radius, strokeWidth, stroke, scale } = this;
@@ -15361,7 +15532,7 @@
15361
15532
  })];
15362
15533
  }
15363
15534
 
15364
- var style$1Q = cB("base-menu-mask", `
15535
+ var style$1P = cB("base-menu-mask", `
15365
15536
  position: absolute;
15366
15537
  left: 0;
15367
15538
  right: 0;
@@ -15384,7 +15555,7 @@
15384
15555
  }
15385
15556
  },
15386
15557
  setup(props) {
15387
- useStyle("-base-menu-mask", style$1Q, vue.toRef(props, "clsPrefix"));
15558
+ useStyle("-base-menu-mask", style$1P, vue.toRef(props, "clsPrefix"));
15388
15559
  const messageRef = vue.ref(null);
15389
15560
  let timerId = null;
15390
15561
  const uncontrolledShowRef = vue.ref(false);
@@ -15572,7 +15743,7 @@
15572
15743
  railColor: "transparent"
15573
15744
  };
15574
15745
 
15575
- function self$1A(vars) {
15746
+ function self$1z(vars) {
15576
15747
  const {
15577
15748
  scrollbarColor,
15578
15749
  scrollbarColorHover,
@@ -15592,13 +15763,13 @@
15592
15763
  const safeTopScrollbarLight = {
15593
15764
  name: "SafeTopScrollbar",
15594
15765
  common: derived,
15595
- self: self$1A
15766
+ self: self$1z
15596
15767
  };
15597
15768
 
15598
15769
  const safeTopScrollbarDark = {
15599
15770
  name: "SafeTopScrollbar",
15600
15771
  common: derived$1,
15601
- self: self$1A
15772
+ self: self$1z
15602
15773
  };
15603
15774
 
15604
15775
  cB("scrollbar", [cM("rtl", `
@@ -15611,7 +15782,7 @@
15611
15782
  right: unset;
15612
15783
  `)])])])]);
15613
15784
 
15614
- var style$1P = cB("safe-top-scrollbar", `
15785
+ var style$1O = cB("safe-top-scrollbar", `
15615
15786
  overflow: hidden;
15616
15787
  position: relative;
15617
15788
  z-index: auto;
@@ -15760,7 +15931,7 @@
15760
15931
  const themeRef = useTheme(
15761
15932
  "SafeTopScrollbar",
15762
15933
  "-safe-top-scrollbar",
15763
- style$1P,
15934
+ style$1O,
15764
15935
  safeTopScrollbarLight,
15765
15936
  props,
15766
15937
  mergedClsPrefixRef
@@ -16494,7 +16665,7 @@
16494
16665
  railColor: "transparent"
16495
16666
  };
16496
16667
 
16497
- function self$1z(vars) {
16668
+ function self$1y(vars) {
16498
16669
  const {
16499
16670
  scrollbarColor,
16500
16671
  scrollbarColorHover,
@@ -16514,13 +16685,13 @@
16514
16685
  const scrollbarLight = {
16515
16686
  name: "Scrollbar",
16516
16687
  common: derived,
16517
- self: self$1z
16688
+ self: self$1y
16518
16689
  };
16519
16690
 
16520
16691
  const scrollbarDark = {
16521
16692
  name: "Scrollbar",
16522
16693
  common: derived$1,
16523
- self: self$1z
16694
+ self: self$1y
16524
16695
  };
16525
16696
 
16526
16697
  var rtlStyle$t = cB("scrollbar", [cM("rtl", `
@@ -16538,7 +16709,7 @@
16538
16709
  style: rtlStyle$t
16539
16710
  };
16540
16711
 
16541
- var style$1O = cB("scrollbar", `
16712
+ var style$1N = cB("scrollbar", `
16542
16713
  overflow: hidden;
16543
16714
  position: relative;
16544
16715
  z-index: auto;
@@ -16681,7 +16852,7 @@
16681
16852
  const themeRef = useTheme(
16682
16853
  "Scrollbar",
16683
16854
  "-scrollbar",
16684
- style$1O,
16855
+ style$1N,
16685
16856
  scrollbarLight,
16686
16857
  props,
16687
16858
  mergedClsPrefixRef
@@ -18053,7 +18224,7 @@
18053
18224
  return treemate;
18054
18225
  }
18055
18226
 
18056
- function self$1y(vars) {
18227
+ function self$1x(vars) {
18057
18228
  const {
18058
18229
  fontBodyMedium,
18059
18230
  fontTitleLarge,
@@ -18085,16 +18256,16 @@
18085
18256
  const emptyLight = {
18086
18257
  name: "Empty",
18087
18258
  common: derived,
18088
- self: self$1y
18259
+ self: self$1x
18089
18260
  };
18090
18261
 
18091
18262
  const emptyDark$1 = {
18092
18263
  name: "Empty",
18093
18264
  common: derived$1,
18094
- self: self$1y
18265
+ self: self$1x
18095
18266
  };
18096
18267
 
18097
- var style$1N = cB("empty", `
18268
+ var style$1M = cB("empty", `
18098
18269
  display: flex;
18099
18270
  flex-direction: column;
18100
18271
  align-items: center;
@@ -18172,7 +18343,7 @@
18172
18343
  const themeRef = useTheme(
18173
18344
  "Empty",
18174
18345
  "-empty",
18175
- style$1N,
18346
+ style$1M,
18176
18347
  emptyLight,
18177
18348
  props,
18178
18349
  mergedClsPrefixRef
@@ -18260,7 +18431,7 @@
18260
18431
  }
18261
18432
  });
18262
18433
 
18263
- function self$1x(vars) {
18434
+ function self$1w(vars) {
18264
18435
  const {
18265
18436
  borderRadius,
18266
18437
  iconMedium,
@@ -18317,7 +18488,7 @@
18317
18488
  Scrollbar: scrollbarLight,
18318
18489
  Empty: emptyLight
18319
18490
  },
18320
- self: self$1x
18491
+ self: self$1w
18321
18492
  });
18322
18493
 
18323
18494
  const internalSelectMenuDark = {
@@ -18327,7 +18498,7 @@
18327
18498
  Scrollbar: scrollbarDark,
18328
18499
  Empty: emptyDark$1
18329
18500
  },
18330
- self: self$1x
18501
+ self: self$1w
18331
18502
  };
18332
18503
 
18333
18504
  cB("base-select-menu", [cM("rtl", `
@@ -18568,7 +18739,7 @@
18568
18739
  })];
18569
18740
  }
18570
18741
 
18571
- var style$1M = cB("base-select-menu", `
18742
+ var style$1L = cB("base-select-menu", `
18572
18743
  line-height: 1.5;
18573
18744
  outline: none;
18574
18745
  z-index: 0;
@@ -18756,7 +18927,7 @@
18756
18927
  const themeRef = useTheme(
18757
18928
  "InternalSelectMenu",
18758
18929
  "-internal-select-menu",
18759
- style$1M,
18930
+ style$1L,
18760
18931
  internalSelectMenuLight,
18761
18932
  props,
18762
18933
  vue.toRef(props, "clsPrefix")
@@ -19224,7 +19395,7 @@
19224
19395
  }
19225
19396
  });
19226
19397
 
19227
- function self$1w(vars) {
19398
+ function self$1v(vars) {
19228
19399
  const {
19229
19400
  fontBodyMedium,
19230
19401
  containerPrimary,
@@ -19251,13 +19422,13 @@
19251
19422
  const popoverLight = {
19252
19423
  name: "Popover",
19253
19424
  common: derived,
19254
- self: self$1w
19425
+ self: self$1v
19255
19426
  };
19256
19427
 
19257
19428
  const popoverDark = {
19258
19429
  name: "Popover",
19259
19430
  common: derived$1,
19260
- self: self$1w
19431
+ self: self$1v
19261
19432
  };
19262
19433
 
19263
19434
  cB("popover", [cM("rtl", `
@@ -19272,7 +19443,7 @@
19272
19443
  right: "left"
19273
19444
  };
19274
19445
  const arrowSize = "var(--u-arrow-height) * 1.414";
19275
- var style$1L = c$1([cB("popover", `
19446
+ var style$1K = c$1([cB("popover", `
19276
19447
  transition:
19277
19448
  box-shadow .3s var(--u-bezier),
19278
19449
  background-color .3s var(--u-bezier),
@@ -19491,7 +19662,7 @@
19491
19662
  const themeRef = useTheme(
19492
19663
  "Popover",
19493
19664
  "-popover",
19494
- style$1L,
19665
+ style$1K,
19495
19666
  popoverLight,
19496
19667
  props,
19497
19668
  mergedClsPrefixRef
@@ -20318,7 +20489,7 @@
20318
20489
  }
20319
20490
  });
20320
20491
 
20321
- function self$1v(vars) {
20492
+ function self$1u(vars) {
20322
20493
  const {
20323
20494
  opacityDisabled,
20324
20495
  borderRadiusSmall: borderRadius,
@@ -20416,13 +20587,13 @@
20416
20587
  const tagLight = {
20417
20588
  name: "Tag",
20418
20589
  common: derived,
20419
- self: self$1v
20590
+ self: self$1u
20420
20591
  };
20421
20592
 
20422
20593
  const tagDark = {
20423
20594
  name: "Tag",
20424
20595
  common: derived$1,
20425
- self: self$1v
20596
+ self: self$1u
20426
20597
  };
20427
20598
 
20428
20599
  var rtlStyle$s = cB("tag", [cM("rtl", `
@@ -20469,7 +20640,7 @@
20469
20640
  }
20470
20641
  };
20471
20642
 
20472
- var style$1K = cB("tag", `
20643
+ var style$1J = cB("tag", `
20473
20644
  white-space: nowrap;
20474
20645
  position: relative;
20475
20646
  box-sizing: border-box;
@@ -20636,7 +20807,7 @@
20636
20807
  const themeRef = useTheme(
20637
20808
  "Tag",
20638
20809
  "-tag",
20639
- style$1K,
20810
+ style$1J,
20640
20811
  tagLight,
20641
20812
  props,
20642
20813
  mergedClsPrefixRef
@@ -21000,7 +21171,7 @@
21000
21171
  }
21001
21172
  });
21002
21173
 
21003
- function self$1u(vars) {
21174
+ function self$1t(vars) {
21004
21175
  const {
21005
21176
  heightSmall,
21006
21177
  heightMedium,
@@ -21020,10 +21191,10 @@
21020
21191
  }
21021
21192
  const skeletonLight$1 = {
21022
21193
  common: derived,
21023
- self: self$1u
21194
+ self: self$1t
21024
21195
  };
21025
21196
 
21026
- var style$1J = c$1([cB("skeleton", `
21197
+ var style$1I = c$1([cB("skeleton", `
21027
21198
  height: 1em;
21028
21199
  width: 100%;
21029
21200
  transition: background-color .3s var(--u-bezier);
@@ -21079,7 +21250,7 @@
21079
21250
  const themeRef = useTheme(
21080
21251
  "Skeleton",
21081
21252
  "-skeleton",
21082
- style$1J,
21253
+ style$1I,
21083
21254
  skeletonLight$1,
21084
21255
  props,
21085
21256
  mergedClsPrefixRef
@@ -21195,7 +21366,7 @@
21195
21366
  }
21196
21367
  });
21197
21368
 
21198
- function self$1t(vars) {
21369
+ function self$1s(vars) {
21199
21370
  const {
21200
21371
  borderRadius,
21201
21372
  iconMedium,
@@ -21353,7 +21524,7 @@
21353
21524
  peers: {
21354
21525
  Popover: popoverLight
21355
21526
  },
21356
- self: self$1t
21527
+ self: self$1s
21357
21528
  });
21358
21529
 
21359
21530
  const internalSelectionDark = {
@@ -21362,7 +21533,7 @@
21362
21533
  peers: {
21363
21534
  Popover: popoverDark
21364
21535
  },
21365
- self: self$1t
21536
+ self: self$1s
21366
21537
  };
21367
21538
 
21368
21539
  cB("base-selection", [cM("rtl", `
@@ -21395,7 +21566,7 @@
21395
21566
  color: var(--u-arrow-color${state}-secondary);
21396
21567
  `)])];
21397
21568
  }
21398
- var style$1I = c$1([cB("base-selection", `
21569
+ var style$1H = c$1([cB("base-selection", `
21399
21570
  position: relative;
21400
21571
  z-index: auto;
21401
21572
  box-shadow: none;
@@ -21746,7 +21917,7 @@
21746
21917
  const themeRef = useTheme(
21747
21918
  "InternalSelection",
21748
21919
  "-internal-selection",
21749
- style$1I,
21920
+ style$1H,
21750
21921
  internalSelectionLight,
21751
21922
  props,
21752
21923
  vue.toRef(props, "clsPrefix")
@@ -22827,7 +22998,7 @@
22827
22998
  })];
22828
22999
  }
22829
23000
 
22830
- var style$1H = c$1([c$1("@keyframes u-base-slot-machine-fade-up-in", `
23001
+ var style$1G = c$1([c$1("@keyframes u-base-slot-machine-fade-up-in", `
22831
23002
  from {
22832
23003
  transform: translateY(60%);
22833
23004
  opacity: 0;
@@ -22946,7 +23117,7 @@
22946
23117
  }
22947
23118
  },
22948
23119
  setup(props) {
22949
- useStyle("-base-slot-machine", style$1H, vue.toRef(props, "clsPrefix"));
23120
+ useStyle("-base-slot-machine", style$1G, vue.toRef(props, "clsPrefix"));
22950
23121
  const oldValueRef = vue.ref();
22951
23122
  const newValueRef = vue.ref();
22952
23123
  const numbersRef = vue.computed(() => {
@@ -23001,7 +23172,7 @@
23001
23172
  }
23002
23173
  });
23003
23174
 
23004
- function self$1s(vars) {
23175
+ function self$1r(vars) {
23005
23176
  const {
23006
23177
  borderRadiusSmall,
23007
23178
  brandPrimary500,
@@ -23037,10 +23208,10 @@
23037
23208
  }
23038
23209
  const typographyLight$1 = {
23039
23210
  common: derived,
23040
- self: self$1s
23211
+ self: self$1r
23041
23212
  };
23042
23213
 
23043
- var style$1G = cB("text", `
23214
+ var style$1F = cB("text", `
23044
23215
  transition: color .3s var(--u-bezier);
23045
23216
  color: var(--u-text-color);
23046
23217
  margin: 0;
@@ -23348,7 +23519,7 @@
23348
23519
  const themeRef = useTheme(
23349
23520
  "Typography",
23350
23521
  "-text",
23351
- style$1G,
23522
+ style$1F,
23352
23523
  typographyLight$1,
23353
23524
  props,
23354
23525
  mergedClsPrefixRef
@@ -23436,7 +23607,7 @@
23436
23607
  }
23437
23608
  });
23438
23609
 
23439
- var style$1F = cB("base-wave", `
23610
+ var style$1E = cB("base-wave", `
23440
23611
  position: absolute;
23441
23612
  left: 0;
23442
23613
  right: 0;
@@ -23454,7 +23625,7 @@
23454
23625
  }
23455
23626
  },
23456
23627
  setup(props) {
23457
- useStyle("-base-wave", style$1F, vue.toRef(props, "clsPrefix"));
23628
+ useStyle("-base-wave", style$1E, vue.toRef(props, "clsPrefix"));
23458
23629
  const selfRef = vue.ref(null);
23459
23630
  const activeRef = vue.ref(false);
23460
23631
  let animationTimerId = null;
@@ -23499,142 +23670,6 @@
23499
23670
  }
23500
23671
  });
23501
23672
 
23502
- function self$1r(vars) {
23503
- const {
23504
- elementsPrimary
23505
- } = vars;
23506
- return {
23507
- color: elementsPrimary,
23508
- opacity1Depth: "0.82",
23509
- opacity2Depth: "0.72",
23510
- opacity3Depth: "0.38",
23511
- opacity4Depth: "0.24",
23512
- opacity5Depth: "0.18"
23513
- };
23514
- }
23515
- const iconLight = {
23516
- name: "Icon",
23517
- common: derived,
23518
- self: self$1r
23519
- };
23520
-
23521
- const iconDark$1 = {
23522
- name: "Icon",
23523
- common: derived$1,
23524
- self: self$1r
23525
- };
23526
-
23527
- var style$1E = cB("icon", `
23528
- height: 1em;
23529
- width: 1em;
23530
- line-height: 1em;
23531
- text-align: center;
23532
- display: inline-block;
23533
- position: relative;
23534
- fill: currentColor;
23535
- transform: translateZ(0);
23536
- `, [cM("color-transition", {
23537
- transition: "color .3s var(--u-bezier)"
23538
- }), cM("depth", {
23539
- color: "var(--u-color)"
23540
- }, [c$1("svg", {
23541
- opacity: "var(--u-opacity)",
23542
- transition: "opacity .3s var(--u-bezier)"
23543
- })]), c$1("svg", {
23544
- height: "100%",
23545
- width: "100%",
23546
- display: "block"
23547
- })]);
23548
-
23549
- const iconProps = {
23550
- ...useTheme.props,
23551
- depth: [String, Number],
23552
- size: [Number, String],
23553
- color: String,
23554
- component: Object,
23555
- onClick: Function
23556
- };
23557
- const UIcon$1 = vue.defineComponent({
23558
- _n_icon__: true,
23559
- name: "Icon",
23560
- inheritAttrs: false,
23561
- props: iconProps,
23562
- setup(props) {
23563
- const {
23564
- mergedClsPrefixRef,
23565
- inlineThemeDisabled
23566
- } = useConfig(props);
23567
- const themeRef = useTheme("Icon", "-icon", style$1E, iconLight, props, mergedClsPrefixRef);
23568
- const cssVarsRef = vue.computed(() => {
23569
- const {
23570
- depth
23571
- } = props;
23572
- const {
23573
- common: {
23574
- cubicBezierEaseInOut
23575
- },
23576
- self
23577
- } = themeRef.value;
23578
- if (depth !== void 0) {
23579
- const {
23580
- color,
23581
- [`opacity${depth}Depth`]: opacity
23582
- } = self;
23583
- return {
23584
- "--u-bezier": cubicBezierEaseInOut,
23585
- "--u-color": color,
23586
- "--u-opacity": opacity
23587
- };
23588
- }
23589
- return {
23590
- "--u-bezier": cubicBezierEaseInOut,
23591
- "--u-color": "",
23592
- "--u-opacity": ""
23593
- };
23594
- });
23595
- const themeClassHandle = inlineThemeDisabled ? useThemeClass("icon", vue.computed(() => `${props.depth || "d"}`), cssVarsRef, props) : void 0;
23596
- return {
23597
- mergedClsPrefix: mergedClsPrefixRef,
23598
- mergedStyle: vue.computed(() => {
23599
- const {
23600
- size,
23601
- color
23602
- } = props;
23603
- return {
23604
- fontSize: formatLength(size),
23605
- color
23606
- };
23607
- }),
23608
- cssVars: inlineThemeDisabled ? void 0 : cssVarsRef,
23609
- themeClass: themeClassHandle?.themeClass,
23610
- onRender: themeClassHandle?.onRender
23611
- };
23612
- },
23613
- render() {
23614
- const {
23615
- $parent,
23616
- depth,
23617
- mergedClsPrefix,
23618
- component,
23619
- onRender,
23620
- themeClass
23621
- } = this;
23622
- if ($parent?.$options?._n_icon__) {
23623
- warn("icon", "don't wrap `u-icon` inside `u-icon`");
23624
- }
23625
- onRender?.();
23626
- return vue.h("i", vue.mergeProps(this.$attrs, {
23627
- role: "img",
23628
- class: [`${mergedClsPrefix}-icon`, themeClass, {
23629
- [`${mergedClsPrefix}-icon--depth`]: depth,
23630
- [`${mergedClsPrefix}-icon--color-transition`]: depth !== void 0
23631
- }],
23632
- style: [this.cssVars, this.mergedStyle],
23633
- onClick: this.onClick
23634
- }), component ? vue.h(component) : this.$slots);
23635
- }
23636
- });
23637
-
23638
23673
  function self$1q(vars) {
23639
23674
  const {
23640
23675
  borderRadius,
@@ -59840,6 +59875,7 @@
59840
59875
  themeOverrides: Object,
59841
59876
  componentOptions: Object,
59842
59877
  icons: Object,
59878
+ iconPacks: Object,
59843
59879
  breakpoints: Object,
59844
59880
  breakpointProps: Object,
59845
59881
  breakpointThemeOverrides: Object,
@@ -59982,6 +60018,12 @@
59982
60018
  } = props;
59983
60019
  return icons === void 0 ? UConfigProvider?.mergedIconsRef.value : icons;
59984
60020
  });
60021
+ const mergedIconPacksRef = vue.computed(() => {
60022
+ const {
60023
+ iconPacks
60024
+ } = props;
60025
+ return iconPacks === void 0 ? UConfigProvider?.mergedIconPacksRef.value : iconPacks;
60026
+ });
59985
60027
  const updateWindowWidth = () => {
59986
60028
  if (isBrowser$1) {
59987
60029
  windowWidthRef.value = window.innerWidth;
@@ -60090,6 +60132,7 @@
60090
60132
  mergedSsrBreakpointWidthRef,
60091
60133
  mergedRtlRef,
60092
60134
  mergedIconsRef,
60135
+ mergedIconPacksRef,
60093
60136
  mergedComponentPropsRef,
60094
60137
  mergedBreakpointPropsRef,
60095
60138
  mergedBreakpointThemeOverridesRef,
@@ -112355,7 +112398,7 @@
112355
112398
  });
112356
112399
  }
112357
112400
 
112358
- var version = "2.0.0-beta.9";
112401
+ var version = "2.0.0";
112359
112402
 
112360
112403
  function create({
112361
112404
  componentPrefix = "U",