@agility/plenum-ui 1.1.6 → 1.1.61

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/lib/index.js CHANGED
@@ -12227,6 +12227,61 @@ var TreeView = function (_a, ref) {
12227
12227
  };
12228
12228
  var _TreeView = React.forwardRef(TreeView);
12229
12229
 
12230
+ /**
12231
+ * Avatar component that shows profile image or name initials of the user
12232
+ */
12233
+ var Avatar = function (_a) {
12234
+ var src = _a.src, status = _a.status, _b = _a.size, size = _b === void 0 ? 'md' : _b, _c = _a.alt, alt = _c === void 0 ? 'Avatar image' : _c, initials = _a.initials;
12235
+ var imageStyles = cn$1('rounded-full', {
12236
+ 'h-6 w-6': size === 'xxs',
12237
+ 'h-8 w-8': size === 'xs',
12238
+ 'h-10 w-10': size === 'sm',
12239
+ 'h-12 w-12': size === 'md',
12240
+ 'h-14 w-14': size === 'lg',
12241
+ 'h-16 w-16': size === 'xl'
12242
+ });
12243
+ var initialsStyles = cn$1('inline-flex items-center justify-center rounded-full bg-gray-500', {
12244
+ 'h-6 w-6': size === 'xxs',
12245
+ 'h-8 w-8': size === 'xs',
12246
+ 'h-10 w-10': size === 'sm',
12247
+ 'h-12 w-12': size === 'md',
12248
+ 'h-14 w-14': size === 'lg',
12249
+ 'h-16 w-16': size === 'xl'
12250
+ });
12251
+ var fontStyles = cn$1('font-medium leading-none text-white uppercase', {
12252
+ 'text-xs': size === 'xxs' || size === 'xs',
12253
+ 'text-sm': size === 'sm',
12254
+ 'text-base': size === 'md',
12255
+ 'text-lg': size === 'lg',
12256
+ 'text-xl': size === 'xl'
12257
+ });
12258
+ var defaultAvatarStyles = cn$1('inline-block rounded-full overflow-hidden bg-gray-100', {
12259
+ 'h-6 w-6': size === 'xxs',
12260
+ 'h-8 w-8': size === 'xs',
12261
+ 'h-10 w-10': size === 'sm',
12262
+ 'h-12 w-12': size === 'md',
12263
+ 'h-14 w-14': size === 'lg',
12264
+ 'h-16 w-16': size === 'xl'
12265
+ });
12266
+ var statusStyles = cn$1('absolute top-0 right-0 block rounded-full ring-2 ring-white', {
12267
+ 'h-1.5 w-1.5': size === 'xxs',
12268
+ 'h-2 w-2': size === 'xs',
12269
+ 'h-2.5 w-2.5': size === 'sm',
12270
+ 'h-3 w-3': size === 'md',
12271
+ 'h-3.5 w-3.5': size === 'lg',
12272
+ 'h-4 w-4': size === 'xl',
12273
+ 'bg-gray-300': status === 'offline',
12274
+ 'bg-red-400': status === 'busy',
12275
+ 'bg-green-400': status === 'online'
12276
+ });
12277
+ return (React__default["default"].createElement("span", { className: "inline-block relative" },
12278
+ src ? (React__default["default"].createElement("img", { className: imageStyles, src: src, alt: alt })) : initials ? (React__default["default"].createElement("span", { className: initialsStyles },
12279
+ React__default["default"].createElement("span", { className: fontStyles }, initials))) : (React__default["default"].createElement("span", { className: defaultAvatarStyles },
12280
+ React__default["default"].createElement("svg", { className: "h-full w-full text-gray-300", fill: "currentColor", viewBox: "0 0 24 24" },
12281
+ React__default["default"].createElement("path", { d: "M24 20.993V24H0v-2.996A14.977 14.977 0 0112.004 15c4.904 0 9.26 2.354 11.996 5.993zM16.002 8.999a4 4 0 11-8 0 4 4 0 018 0z" })))),
12282
+ status && React__default["default"].createElement("span", { className: statusStyles })));
12283
+ };
12284
+
12230
12285
  /** Primary UI component for user interaction */
12231
12286
  var InputCounter = function (_a) {
12232
12287
  var _b = _a.current, current = _b === void 0 ? 0 : _b, limit = _a.limit;
@@ -12548,6 +12603,7 @@ var Checkbox = function (_a) {
12548
12603
  message && (React__default["default"].createElement("p", { id: "".concat(id, "-description"), className: "text-gray-500" }, message)))));
12549
12604
  };
12550
12605
 
12606
+ exports.Avatar = Avatar;
12551
12607
  exports.Button = Button;
12552
12608
  exports.Checkbox = Checkbox;
12553
12609
  exports.Combobox = Combobox;