@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.d.ts CHANGED
@@ -3,6 +3,7 @@ export * from './components/Combobox';
3
3
  export * from './components/Dropdown';
4
4
  export * from './components/Switch';
5
5
  export * from './components/TreeView';
6
+ export * from './components/Avatar';
6
7
  export * from './components/Forms/TextInput';
7
8
  export * from './components/Forms/TextInputAddon';
8
9
  export * from './components/Forms/TextInputSelect';
package/lib/index.esm.js CHANGED
@@ -12201,6 +12201,61 @@ var TreeView = function (_a, ref) {
12201
12201
  };
12202
12202
  var _TreeView = forwardRef(TreeView);
12203
12203
 
12204
+ /**
12205
+ * Avatar component that shows profile image or name initials of the user
12206
+ */
12207
+ var Avatar = function (_a) {
12208
+ 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;
12209
+ var imageStyles = cn$1('rounded-full', {
12210
+ 'h-6 w-6': size === 'xxs',
12211
+ 'h-8 w-8': size === 'xs',
12212
+ 'h-10 w-10': size === 'sm',
12213
+ 'h-12 w-12': size === 'md',
12214
+ 'h-14 w-14': size === 'lg',
12215
+ 'h-16 w-16': size === 'xl'
12216
+ });
12217
+ var initialsStyles = cn$1('inline-flex items-center justify-center rounded-full bg-gray-500', {
12218
+ 'h-6 w-6': size === 'xxs',
12219
+ 'h-8 w-8': size === 'xs',
12220
+ 'h-10 w-10': size === 'sm',
12221
+ 'h-12 w-12': size === 'md',
12222
+ 'h-14 w-14': size === 'lg',
12223
+ 'h-16 w-16': size === 'xl'
12224
+ });
12225
+ var fontStyles = cn$1('font-medium leading-none text-white uppercase', {
12226
+ 'text-xs': size === 'xxs' || size === 'xs',
12227
+ 'text-sm': size === 'sm',
12228
+ 'text-base': size === 'md',
12229
+ 'text-lg': size === 'lg',
12230
+ 'text-xl': size === 'xl'
12231
+ });
12232
+ var defaultAvatarStyles = cn$1('inline-block rounded-full overflow-hidden bg-gray-100', {
12233
+ 'h-6 w-6': size === 'xxs',
12234
+ 'h-8 w-8': size === 'xs',
12235
+ 'h-10 w-10': size === 'sm',
12236
+ 'h-12 w-12': size === 'md',
12237
+ 'h-14 w-14': size === 'lg',
12238
+ 'h-16 w-16': size === 'xl'
12239
+ });
12240
+ var statusStyles = cn$1('absolute top-0 right-0 block rounded-full ring-2 ring-white', {
12241
+ 'h-1.5 w-1.5': size === 'xxs',
12242
+ 'h-2 w-2': size === 'xs',
12243
+ 'h-2.5 w-2.5': size === 'sm',
12244
+ 'h-3 w-3': size === 'md',
12245
+ 'h-3.5 w-3.5': size === 'lg',
12246
+ 'h-4 w-4': size === 'xl',
12247
+ 'bg-gray-300': status === 'offline',
12248
+ 'bg-red-400': status === 'busy',
12249
+ 'bg-green-400': status === 'online'
12250
+ });
12251
+ return (React__default.createElement("span", { className: "inline-block relative" },
12252
+ src ? (React__default.createElement("img", { className: imageStyles, src: src, alt: alt })) : initials ? (React__default.createElement("span", { className: initialsStyles },
12253
+ React__default.createElement("span", { className: fontStyles }, initials))) : (React__default.createElement("span", { className: defaultAvatarStyles },
12254
+ React__default.createElement("svg", { className: "h-full w-full text-gray-300", fill: "currentColor", viewBox: "0 0 24 24" },
12255
+ React__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" })))),
12256
+ status && React__default.createElement("span", { className: statusStyles })));
12257
+ };
12258
+
12204
12259
  /** Primary UI component for user interaction */
12205
12260
  var InputCounter = function (_a) {
12206
12261
  var _b = _a.current, current = _b === void 0 ? 0 : _b, limit = _a.limit;
@@ -12522,5 +12577,5 @@ var Checkbox = function (_a) {
12522
12577
  message && (React__default.createElement("p", { id: "".concat(id, "-description"), className: "text-gray-500" }, message)))));
12523
12578
  };
12524
12579
 
12525
- export { Button, Checkbox, Combobox, Dropdown, Placeholder, Radio, Select, Switch, TextInput, TextInputAddon, TextInputSelect, _Textarea as Textarea, _TreeView as TreeView };
12580
+ export { Avatar, Button, Checkbox, Combobox, Dropdown, Placeholder, Radio, Select, Switch, TextInput, TextInputAddon, TextInputSelect, _Textarea as Textarea, _TreeView as TreeView };
12526
12581
  //# sourceMappingURL=index.esm.js.map