@algolia/satellite 1.3.1 → 1.4.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.
- package/dist/cjs/Actions/ToggleButton/ToggleButton.d.ts +9 -22
- package/dist/cjs/Actions/ToggleButton/ToggleButton.js +19 -32
- package/dist/cjs/Actions/ToggleButton/ToggleButtonBase.d.ts +16 -0
- package/dist/cjs/Actions/ToggleButton/ToggleButtonBase.js +58 -0
- package/dist/cjs/Actions/ToggleGroup/ToggleGroup.d.ts +64 -0
- package/dist/cjs/Actions/ToggleGroup/ToggleGroup.js +73 -0
- package/dist/cjs/Actions/ToggleGroup/ToggleGroup.tailwind.d.ts +5 -0
- package/dist/cjs/Actions/ToggleGroup/ToggleGroup.tailwind.js +34 -0
- package/dist/cjs/Actions/index.d.ts +1 -0
- package/dist/cjs/Actions/index.js +11 -0
- package/dist/cjs/Indicators/Skeleton/Skeleton.d.ts +12 -0
- package/dist/cjs/Indicators/Skeleton/Skeleton.js +39 -0
- package/dist/cjs/Indicators/Skeleton/index.d.ts +1 -0
- package/dist/cjs/Indicators/Skeleton/index.js +16 -0
- package/dist/cjs/styles/tailwind.config.js +1 -1
- package/dist/esm/Actions/ToggleButton/ToggleButton.d.ts +9 -22
- package/dist/esm/Actions/ToggleButton/ToggleButton.js +20 -33
- package/dist/esm/Actions/ToggleButton/ToggleButtonBase.d.ts +16 -0
- package/dist/esm/Actions/ToggleButton/ToggleButtonBase.js +51 -0
- package/dist/esm/Actions/ToggleGroup/ToggleGroup.d.ts +64 -0
- package/dist/esm/Actions/ToggleGroup/ToggleGroup.js +64 -0
- package/dist/esm/Actions/ToggleGroup/ToggleGroup.tailwind.d.ts +5 -0
- package/dist/esm/Actions/ToggleGroup/ToggleGroup.tailwind.js +33 -0
- package/dist/esm/Actions/index.d.ts +1 -0
- package/dist/esm/Actions/index.js +1 -0
- package/dist/esm/Indicators/Skeleton/Skeleton.d.ts +12 -0
- package/dist/esm/Indicators/Skeleton/Skeleton.js +32 -0
- package/dist/esm/Indicators/Skeleton/index.d.ts +1 -0
- package/dist/esm/Indicators/Skeleton/index.js +1 -0
- package/dist/esm/styles/tailwind.config.js +1 -1
- package/dist/satellite.min.css +1 -1
- package/package.json +7 -7
@@ -1,27 +1,14 @@
|
|
1
|
+
/// <reference types="react" />
|
1
2
|
import type { ToggleProps } from "@radix-ui/react-toggle";
|
2
|
-
import type {
|
3
|
-
|
4
|
-
import type { ButtonSize } from "../Button/types";
|
5
|
-
declare type InputElementProps = InputHTMLAttributes<HTMLInputElement>;
|
6
|
-
declare type ToggleButtonSharedProps = {
|
7
|
-
id?: InputElementProps["id"];
|
8
|
-
className?: InputElementProps["className"];
|
9
|
-
style?: InputElementProps["style"];
|
10
|
-
autoFocus?: InputElementProps["autoFocus"];
|
11
|
-
disabled?: InputElementProps["disabled"];
|
3
|
+
import type { ToggleButtonBaseProps } from "./ToggleButtonBase";
|
4
|
+
export declare type ToggleButtonProps = {
|
12
5
|
pressed?: ToggleProps["pressed"];
|
13
6
|
defaultPressed?: ToggleProps["defaultPressed"];
|
14
7
|
onPressedChange?: ToggleProps["onPressedChange"];
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
declare type TextToggleButtonProps = {
|
22
|
-
icon?: IconComponentType;
|
23
|
-
children: ReactNode;
|
24
|
-
};
|
25
|
-
export declare type ToggleButtonProps = ToggleButtonSharedProps & (IconOnlyToggleButtonProps | TextToggleButtonProps);
|
8
|
+
} & ToggleButtonBaseProps;
|
9
|
+
/**
|
10
|
+
* The `ToggleButton` component is a button that toggles between two states.
|
11
|
+
*
|
12
|
+
* See the [ToggleButton documentation page](https://satellite.algolia.com/components/actions/toggle-button) for more information.
|
13
|
+
*/
|
26
14
|
export declare const ToggleButton: import("react").ForwardRefExoticComponent<ToggleButtonProps & import("react").RefAttributes<HTMLButtonElement>>;
|
27
|
-
export {};
|
@@ -7,50 +7,37 @@ Object.defineProperty(exports, "__esModule", {
|
|
7
7
|
exports.ToggleButton = void 0;
|
8
8
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
9
9
|
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
10
|
-
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
11
10
|
var _reactToggle = require("@radix-ui/react-toggle");
|
12
|
-
var _clsx = _interopRequireDefault(require("clsx"));
|
13
11
|
var _react = require("react");
|
14
|
-
var
|
15
|
-
var _satellitePrefixer = _interopRequireDefault(require("../../styles/helpers/satellitePrefixer"));
|
16
|
-
var _styles = require("../Button/styles");
|
12
|
+
var _ToggleButtonBase = require("./ToggleButtonBase");
|
17
13
|
var _jsxRuntime = require("react/jsx-runtime");
|
18
|
-
var _excluded = ["
|
19
|
-
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10;
|
14
|
+
var _excluded = ["size", "icon", "children", "label"];
|
20
15
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
21
16
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
17
|
+
/**
|
18
|
+
* The `ToggleButton` component is a button that toggles between two states.
|
19
|
+
*
|
20
|
+
* See the [ToggleButton documentation page](https://satellite.algolia.com/components/actions/toggle-button) for more information.
|
21
|
+
*/
|
27
22
|
var ToggleButton = exports.ToggleButton = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
28
|
-
var isIconOnly = !props.children;
|
29
23
|
var _label$props = _objectSpread({
|
30
24
|
label: undefined
|
31
25
|
}, props),
|
32
|
-
|
33
|
-
|
34
|
-
size = _label$props$size === void 0 ? "medium" : _label$props$size,
|
35
|
-
Icon = _label$props.icon,
|
26
|
+
size = _label$props.size,
|
27
|
+
icon = _label$props.icon,
|
36
28
|
children = _label$props.children,
|
37
29
|
label = _label$props.label,
|
38
30
|
rest = (0, _objectWithoutProperties2["default"])(_label$props, _excluded);
|
39
|
-
return /*#__PURE__*/(0, _jsxRuntime.jsx)(
|
40
|
-
|
41
|
-
|
31
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactToggle.Toggle, _objectSpread(_objectSpread({
|
32
|
+
asChild: true
|
33
|
+
}, rest), {}, {
|
34
|
+
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_ToggleButtonBase.ToggleButtonBase, {
|
42
35
|
ref: ref,
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
className: (0, _satellitePrefixer["default"])(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["shrink-0 h-4 w-4 text-grey-600 group-aria-pressed/toggle-button:text-inherit group-disabled/toggle-button:text-inherit"])))
|
50
|
-
}), !!children && /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
51
|
-
children: children
|
52
|
-
})]
|
53
|
-
}))
|
54
|
-
});
|
36
|
+
size: size,
|
37
|
+
icon: icon,
|
38
|
+
label: label,
|
39
|
+
children: children
|
40
|
+
})
|
41
|
+
}));
|
55
42
|
});
|
56
43
|
ToggleButton.displayName = "ToggleButton";
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import type { ButtonHTMLAttributes, ReactNode } from "react";
|
2
|
+
import type { IconComponentType } from "../../Icons";
|
3
|
+
import type { ButtonSize } from "../Button/types";
|
4
|
+
declare type IconOnlyToggleButtonBaseProps = {
|
5
|
+
icon: IconComponentType;
|
6
|
+
label: string;
|
7
|
+
};
|
8
|
+
declare type TextToggleButtonBaseProps = {
|
9
|
+
icon?: IconComponentType;
|
10
|
+
children: ReactNode;
|
11
|
+
};
|
12
|
+
export declare type ToggleButtonBaseProps = Pick<ButtonHTMLAttributes<HTMLButtonElement>, "id" | "className" | "style" | "autoFocus" | "disabled"> & {
|
13
|
+
size?: ButtonSize;
|
14
|
+
} & (IconOnlyToggleButtonBaseProps | TextToggleButtonBaseProps);
|
15
|
+
export declare const ToggleButtonBase: import("react").ForwardRefExoticComponent<ToggleButtonBaseProps & import("react").RefAttributes<HTMLButtonElement>>;
|
16
|
+
export {};
|
@@ -0,0 +1,58 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
5
|
+
value: true
|
6
|
+
});
|
7
|
+
exports.ToggleButtonBase = void 0;
|
8
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
9
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
10
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
11
|
+
var _clsx = _interopRequireDefault(require("clsx"));
|
12
|
+
var _react = require("react");
|
13
|
+
var _Overlay = require("../../Overlay");
|
14
|
+
var _satellitePrefixer = _interopRequireDefault(require("../../styles/helpers/satellitePrefixer"));
|
15
|
+
var _styles = require("../Button/styles");
|
16
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
17
|
+
var _excluded = ["className", "size", "icon", "children", "label"];
|
18
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11;
|
19
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
20
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
21
|
+
var ICON_ONLY_CLASSNAMES = {
|
22
|
+
small: (0, _satellitePrefixer["default"])(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["h-6 w-6"]))),
|
23
|
+
medium: (0, _satellitePrefixer["default"])(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["h-8 w-8"]))),
|
24
|
+
large: (0, _satellitePrefixer["default"])(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["h-10 w-10"])))
|
25
|
+
};
|
26
|
+
var ToggleButtonBase = exports.ToggleButtonBase = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
27
|
+
var isIconOnly = !props.children;
|
28
|
+
var _label$props = _objectSpread({
|
29
|
+
label: undefined
|
30
|
+
}, props),
|
31
|
+
className = _label$props.className,
|
32
|
+
_label$props$size = _label$props.size,
|
33
|
+
size = _label$props$size === void 0 ? "medium" : _label$props$size,
|
34
|
+
Icon = _label$props.icon,
|
35
|
+
children = _label$props.children,
|
36
|
+
label = _label$props.label,
|
37
|
+
rest = (0, _objectWithoutProperties2["default"])(_label$props, _excluded);
|
38
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_Overlay.TooltipWrapper, {
|
39
|
+
content: label,
|
40
|
+
children: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
41
|
+
className: (0, _satellitePrefixer["default"])(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["inline-flex"]))),
|
42
|
+
children: /*#__PURE__*/(0, _jsxRuntime.jsxs)("button", _objectSpread(_objectSpread({
|
43
|
+
ref: ref,
|
44
|
+
type: "button",
|
45
|
+
"aria-label": label,
|
46
|
+
className: (0, _clsx["default"])((0, _satellitePrefixer["default"])(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["inline-flex items-center justify-center gap-1 min-w-min whitespace-nowrap typo-display-body"]))), (0, _satellitePrefixer["default"])(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["group/toggle-button rounded focusable-visible disabled:cursor-not-allowed"]))), (0, _satellitePrefixer["default"])(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["data-[state=on]:text-accent-600 disabled:!text-grey-300"]))), (0, _satellitePrefixer["default"])(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["bg-white data-[state=off]:hover:bg-grey-100 data-[state=on]:bg-accent-100 disabled:!bg-grey-50"]))), (0, _satellitePrefixer["default"])(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["border border-grey-200 data-[state=on]:border-accent-600 disabled:!border-grey-200"]))), !isIconOnly && (0, _satellitePrefixer["default"])(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["px-3"]))), isIconOnly ? ICON_ONLY_CLASSNAMES[size] : _styles.BUTTON_SIZE_CLASSNAMES[size], className)
|
47
|
+
}, rest), {}, {
|
48
|
+
children: [!!Icon && /*#__PURE__*/(0, _jsxRuntime.jsx)(Icon, {
|
49
|
+
"aria-hidden": "true",
|
50
|
+
className: (0, _satellitePrefixer["default"])(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["shrink-0 h-4 w-4 text-grey-600 group-data-[state=on]/toggle-button:text-inherit group-disabled/toggle-button:text-inherit"])))
|
51
|
+
}), !!children && /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
52
|
+
children: children
|
53
|
+
})]
|
54
|
+
}))
|
55
|
+
})
|
56
|
+
});
|
57
|
+
});
|
58
|
+
ToggleButtonBase.displayName = "ToggleButtonBase";
|
@@ -0,0 +1,64 @@
|
|
1
|
+
import type { ToggleGroupItemProps as RadixToggleGroupItemProps, ToggleGroupMultipleProps as RadixToggleGroupMultipleProps, ToggleGroupImplProps as RadixToggleGroupSharedProps, ToggleGroupSingleProps as RadixToggleGroupSingleProps } from "@radix-ui/react-toggle-group";
|
2
|
+
import type { FC } from "react";
|
3
|
+
import type { ToggleButtonBaseProps } from "../ToggleButton/ToggleButtonBase";
|
4
|
+
declare type ToggleGroupSharedProps = {
|
5
|
+
/** @ignore */
|
6
|
+
className?: string;
|
7
|
+
/**
|
8
|
+
* Defines whether the `ToggleGroup` is disabled,
|
9
|
+
* preventing the user from interacting with the toggle group and all its items.
|
10
|
+
*/
|
11
|
+
disabled?: RadixToggleGroupSharedProps["disabled"];
|
12
|
+
};
|
13
|
+
declare type ToggleGroupSingleProps = {
|
14
|
+
/** Defines whether a single or multiple items can be pressed at a time. */
|
15
|
+
type: "single";
|
16
|
+
/**
|
17
|
+
* Defines the controlled value of the pressed item.
|
18
|
+
* Must be used in conjunction with `onValueChange`.
|
19
|
+
*/
|
20
|
+
value?: RadixToggleGroupSingleProps["value"];
|
21
|
+
/**
|
22
|
+
* Defines the value of the item to show as pressed when initially rendered.
|
23
|
+
* Use when you do not need to control the state of the items.
|
24
|
+
*/
|
25
|
+
defaultValue?: RadixToggleGroupSingleProps["defaultValue"];
|
26
|
+
/** Defines the event handler called when the pressed state of an item changes. */
|
27
|
+
onChange?: RadixToggleGroupSingleProps["onValueChange"];
|
28
|
+
};
|
29
|
+
declare type ToggleGroupMultipleProps = {
|
30
|
+
/** Defines whether a single or multiple items can be pressed at a time. */
|
31
|
+
type: "multiple";
|
32
|
+
/**
|
33
|
+
* Defines the controlled value of the pressed items.
|
34
|
+
* Must be used in conjunction with `onValueChange`.
|
35
|
+
*/
|
36
|
+
value?: RadixToggleGroupMultipleProps["value"];
|
37
|
+
/**
|
38
|
+
* Defines the values of the items to show as pressed when initially rendered.
|
39
|
+
* Use when you do not need to control the state of the items.
|
40
|
+
*/
|
41
|
+
defaultValue?: RadixToggleGroupMultipleProps["defaultValue"];
|
42
|
+
/** Defines the event handler called when the pressed state of an item changes. */
|
43
|
+
onChange?: RadixToggleGroupMultipleProps["onValueChange"];
|
44
|
+
};
|
45
|
+
export declare type ToggleGroupProps = ToggleGroupSharedProps & (ToggleGroupSingleProps | ToggleGroupMultipleProps);
|
46
|
+
declare type ToggleGroupComponent = FC<ToggleGroupProps> & {
|
47
|
+
Item: FC<ToggleGroupItemProps>;
|
48
|
+
};
|
49
|
+
/**
|
50
|
+
* The `ToggleGroupItem` component is a toggle group item that allows users to select one or more options.
|
51
|
+
*
|
52
|
+
* See the [ToggleGroupItem documentation page](https://satellite.algolia.com/components/actions/toggle-group) for more information.
|
53
|
+
*/
|
54
|
+
export declare type ToggleGroupItemProps = ToggleButtonBaseProps & {
|
55
|
+
/** Defines a unique value for the item. */
|
56
|
+
value: RadixToggleGroupItemProps["value"];
|
57
|
+
};
|
58
|
+
/**
|
59
|
+
* The `ToggleGroup` component is a toggle group that allows users to select one or more options.
|
60
|
+
*
|
61
|
+
* See the [ToggleGroup documentation page](https://satellite.algolia.com/components/actions/toggle-group) for more information.
|
62
|
+
*/
|
63
|
+
export declare const ToggleGroup: ToggleGroupComponent;
|
64
|
+
export {};
|
@@ -0,0 +1,73 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
6
|
+
value: true
|
7
|
+
});
|
8
|
+
exports.ToggleGroup = void 0;
|
9
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
10
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
11
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
12
|
+
var RadixToggleGroup = _interopRequireWildcard(require("@radix-ui/react-toggle-group"));
|
13
|
+
var _clsx = _interopRequireDefault(require("clsx"));
|
14
|
+
var _react = require("react");
|
15
|
+
var _satellitePrefixer = _interopRequireDefault(require("../../styles/helpers/satellitePrefixer"));
|
16
|
+
var _ToggleButtonBase = require("../ToggleButton/ToggleButtonBase");
|
17
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
18
|
+
var _templateObject, _templateObject2;
|
19
|
+
var _excluded = ["size", "icon", "children", "label", "className"],
|
20
|
+
_excluded2 = ["onChange", "className", "children"];
|
21
|
+
/**
|
22
|
+
* The `ToggleGroupItem` component is a toggle group item that allows users to select one or more options.
|
23
|
+
*
|
24
|
+
* See the [ToggleGroupItem documentation page](https://satellite.algolia.com/components/actions/toggle-group) for more information.
|
25
|
+
*/
|
26
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
27
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
28
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
29
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
30
|
+
var ToggleGroupItem = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
31
|
+
var _label$props = _objectSpread({
|
32
|
+
label: undefined
|
33
|
+
}, props),
|
34
|
+
size = _label$props.size,
|
35
|
+
icon = _label$props.icon,
|
36
|
+
children = _label$props.children,
|
37
|
+
label = _label$props.label,
|
38
|
+
className = _label$props.className,
|
39
|
+
rest = (0, _objectWithoutProperties2["default"])(_label$props, _excluded);
|
40
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsx)(RadixToggleGroup.Item, _objectSpread(_objectSpread({
|
41
|
+
asChild: true
|
42
|
+
}, rest), {}, {
|
43
|
+
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_ToggleButtonBase.ToggleButtonBase, {
|
44
|
+
ref: ref,
|
45
|
+
size: size,
|
46
|
+
icon: icon,
|
47
|
+
label: label,
|
48
|
+
className: (0, _clsx["default"])((0, _satellitePrefixer["default"])(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["toggle-group-item"]))), className),
|
49
|
+
children: children
|
50
|
+
})
|
51
|
+
}));
|
52
|
+
});
|
53
|
+
ToggleGroupItem.displayName = "ToggleGroupItem";
|
54
|
+
|
55
|
+
/**
|
56
|
+
* The `ToggleGroup` component is a toggle group that allows users to select one or more options.
|
57
|
+
*
|
58
|
+
* See the [ToggleGroup documentation page](https://satellite.algolia.com/components/actions/toggle-group) for more information.
|
59
|
+
*/
|
60
|
+
var ToggleGroup = exports.ToggleGroup = function ToggleGroup(_ref) {
|
61
|
+
var onChange = _ref.onChange,
|
62
|
+
className = _ref.className,
|
63
|
+
children = _ref.children,
|
64
|
+
rest = (0, _objectWithoutProperties2["default"])(_ref, _excluded2);
|
65
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsx)(RadixToggleGroup.Root, _objectSpread(_objectSpread({
|
66
|
+
onValueChange: onChange,
|
67
|
+
className: (0, _clsx["default"])((0, _satellitePrefixer["default"])(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["toggle-group"]))), className)
|
68
|
+
}, rest), {}, {
|
69
|
+
children: children
|
70
|
+
}));
|
71
|
+
};
|
72
|
+
ToggleGroup.Item = ToggleGroupItem;
|
73
|
+
ToggleGroup.displayName = "ToggleGroup";
|
@@ -0,0 +1,34 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
// @ts-check
|
4
|
+
var plugin = require("tailwindcss/plugin");
|
5
|
+
var toggleGroupPlugin = plugin(function (_ref) {
|
6
|
+
var addComponents = _ref.addComponents;
|
7
|
+
addComponents({
|
8
|
+
".toggle-group": {
|
9
|
+
display: "flex",
|
10
|
+
flexWrap: "nowrap",
|
11
|
+
"& > :not(:first-child):not(:last-child) .toggle-group-item": {
|
12
|
+
borderRadius: "0px"
|
13
|
+
},
|
14
|
+
"& > :first-child .toggle-group-item": {
|
15
|
+
borderTopRightRadius: "0px",
|
16
|
+
borderBottomRightRadius: "0px"
|
17
|
+
},
|
18
|
+
"& > :not(:first-child) .toggle-group-item": {
|
19
|
+
marginLeft: "-1px"
|
20
|
+
},
|
21
|
+
"& > :last-child .toggle-group-item": {
|
22
|
+
borderTopLeftRadius: "0px",
|
23
|
+
borderBottomLeftRadius: "0px"
|
24
|
+
},
|
25
|
+
"& [data-state=on]": {
|
26
|
+
zIndex: "1"
|
27
|
+
},
|
28
|
+
"& .toggle-group-item:focus-visible": {
|
29
|
+
zIndex: "2"
|
30
|
+
}
|
31
|
+
}
|
32
|
+
});
|
33
|
+
});
|
34
|
+
module.exports = toggleGroupPlugin;
|
@@ -5,4 +5,5 @@ export * from "./IconButton/IconButton";
|
|
5
5
|
export * from "./IconButtonLink/IconButtonLink";
|
6
6
|
export * from "./Switch";
|
7
7
|
export * from "./ToggleButton/ToggleButton";
|
8
|
+
export * from "./ToggleGroup/ToggleGroup";
|
8
9
|
export type { ButtonSize, ButtonVariant } from "./Button/types";
|
@@ -79,4 +79,15 @@ Object.keys(_ToggleButton).forEach(function (key) {
|
|
79
79
|
return _ToggleButton[key];
|
80
80
|
}
|
81
81
|
});
|
82
|
+
});
|
83
|
+
var _ToggleGroup = require("./ToggleGroup/ToggleGroup");
|
84
|
+
Object.keys(_ToggleGroup).forEach(function (key) {
|
85
|
+
if (key === "default" || key === "__esModule") return;
|
86
|
+
if (key in exports && exports[key] === _ToggleGroup[key]) return;
|
87
|
+
Object.defineProperty(exports, key, {
|
88
|
+
enumerable: true,
|
89
|
+
get: function get() {
|
90
|
+
return _ToggleGroup[key];
|
91
|
+
}
|
92
|
+
});
|
82
93
|
});
|
@@ -0,0 +1,12 @@
|
|
1
|
+
import type { FC } from "react";
|
2
|
+
export interface SkeletonProps {
|
3
|
+
className?: string;
|
4
|
+
circle?: boolean;
|
5
|
+
image?: boolean;
|
6
|
+
}
|
7
|
+
/**
|
8
|
+
* The `Skeleton` component is used to display a placeholder during loading.
|
9
|
+
*
|
10
|
+
* See the [Skeleton documentation page](https://satellite.algolia.com/layouts/skeleton) for more information.
|
11
|
+
*/
|
12
|
+
export declare const Skeleton: FC<SkeletonProps>;
|
@@ -0,0 +1,39 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
5
|
+
value: true
|
6
|
+
});
|
7
|
+
exports.Skeleton = void 0;
|
8
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
9
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
10
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
11
|
+
var _clsx = _interopRequireDefault(require("clsx"));
|
12
|
+
var _Icons = require("../../Icons");
|
13
|
+
var _satellitePrefixer = _interopRequireDefault(require("../../styles/helpers/satellitePrefixer"));
|
14
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
15
|
+
var _templateObject, _templateObject2;
|
16
|
+
var _excluded = ["circle", "image", "className"];
|
17
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
18
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
19
|
+
/**
|
20
|
+
* The `Skeleton` component is used to display a placeholder during loading.
|
21
|
+
*
|
22
|
+
* See the [Skeleton documentation page](https://satellite.algolia.com/layouts/skeleton) for more information.
|
23
|
+
*/
|
24
|
+
|
25
|
+
var Skeleton = exports.Skeleton = function Skeleton(_ref) {
|
26
|
+
var _ref$circle = _ref.circle,
|
27
|
+
circle = _ref$circle === void 0 ? false : _ref$circle,
|
28
|
+
_ref$image = _ref.image,
|
29
|
+
image = _ref$image === void 0 ? false : _ref$image,
|
30
|
+
className = _ref.className,
|
31
|
+
props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
|
32
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsx)("div", _objectSpread(_objectSpread({}, props), {}, {
|
33
|
+
"aria-hidden": true,
|
34
|
+
className: (0, _clsx["default"])((0, _satellitePrefixer["default"])(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["flex animate-pulse bg-grey-200 ", ""])), circle ? "rounded-full aspect-square max-w-fit" : "rounded"), className),
|
35
|
+
children: image ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_Icons.ImageIcon, {
|
36
|
+
className: (0, _satellitePrefixer["default"])(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["mx-auto self-center text-grey-300/50 w-[40%] h-[40%] max-w-[32px] max-h-[32px]"])))
|
37
|
+
}) : null
|
38
|
+
}));
|
39
|
+
};
|
@@ -0,0 +1 @@
|
|
1
|
+
export * from "./Skeleton";
|
@@ -0,0 +1,16 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
var _Skeleton = require("./Skeleton");
|
7
|
+
Object.keys(_Skeleton).forEach(function (key) {
|
8
|
+
if (key === "default" || key === "__esModule") return;
|
9
|
+
if (key in exports && exports[key] === _Skeleton[key]) return;
|
10
|
+
Object.defineProperty(exports, key, {
|
11
|
+
enumerable: true,
|
12
|
+
get: function get() {
|
13
|
+
return _Skeleton[key];
|
14
|
+
}
|
15
|
+
});
|
16
|
+
});
|
@@ -141,5 +141,5 @@ module.exports = {
|
|
141
141
|
}
|
142
142
|
}
|
143
143
|
},
|
144
|
-
plugins: [require("@tailwindcss/container-queries"), require("./base.tailwind"), require("../Helpers/utilities/overlay.tailwind"), require("../Helpers/utilities/utilities.tailwind"), require("../Helpers/utilities/focusable.tailwind"), require("../Typography/Typography.tailwind"), require("../Layout/FlexGrid/FlexGrid.tailwind"), require("../Fields/AutoComplete/AutoComplete.tailwind"), require("../Actions/Button/Button.tailwind"), require("../Layout/Card/Card.tailwind"), require("../Fields/Checkbox/Checkbox.tailwind"), require("../Indicators/EmptyState/EmptyState.tailwind"), require("../Indicators/Toast/Toast.tailwind"), require("../Helpers/HelpUnderline/HelpUnderline.tailwind"), require("../Fields/Input/Input.tailwind"), require("../Helpers/InstantSearch/InstantSearch.tailwind"), require("../Indicators/KeyboardKey/KeyboardKey.tailwind"), require("../Helpers/Medallion/Medallion.tailwind"), require("../Overlay/Modal/Modal.tailwind"), require("../Indicators/ProgressBar/ProgressBar.tailwind"), require("../Indicators/ProgressSpinner/ProgressSpinner.tailwind"), require("../Fields/RadioGroup/RadioButton.tailwind"), require("../Indicators/ScrollIndicator/ScrollIndicator.tailwind"), require("../Fields/Select/Select.tailwind"), require("../Helpers/Separator/Separator.tailwind"), require("../Actions/Switch/Switch.tailwind"), require("../Navigation/Tabs/Tabs.tailwind"), require("../Layout/Tables/DataTable/DataTable.tailwind"), require("../Layout/Tables/Table/Table.tailwind"), require("../Indicators/Tag/Tag.tailwind"), require("../Fields/TextArea/TextArea.tailwind"), require("../Fields/Toggle/Toggle.tailwind"), require("../Overlay/Tooltip/Tooltip.tailwind"), require("../Helpers/UserContent/UserContent.tailwind"), require("../Fields/DatePicker/DatePicker.tailwind")]
|
144
|
+
plugins: [require("@tailwindcss/container-queries"), require("./base.tailwind"), require("../Helpers/utilities/overlay.tailwind"), require("../Helpers/utilities/utilities.tailwind"), require("../Helpers/utilities/focusable.tailwind"), require("../Typography/Typography.tailwind"), require("../Layout/FlexGrid/FlexGrid.tailwind"), require("../Fields/AutoComplete/AutoComplete.tailwind"), require("../Actions/Button/Button.tailwind"), require("../Actions/ToggleGroup/ToggleGroup.tailwind"), require("../Layout/Card/Card.tailwind"), require("../Fields/Checkbox/Checkbox.tailwind"), require("../Indicators/EmptyState/EmptyState.tailwind"), require("../Indicators/Toast/Toast.tailwind"), require("../Helpers/HelpUnderline/HelpUnderline.tailwind"), require("../Fields/Input/Input.tailwind"), require("../Helpers/InstantSearch/InstantSearch.tailwind"), require("../Indicators/KeyboardKey/KeyboardKey.tailwind"), require("../Helpers/Medallion/Medallion.tailwind"), require("../Overlay/Modal/Modal.tailwind"), require("../Indicators/ProgressBar/ProgressBar.tailwind"), require("../Indicators/ProgressSpinner/ProgressSpinner.tailwind"), require("../Fields/RadioGroup/RadioButton.tailwind"), require("../Indicators/ScrollIndicator/ScrollIndicator.tailwind"), require("../Fields/Select/Select.tailwind"), require("../Helpers/Separator/Separator.tailwind"), require("../Actions/Switch/Switch.tailwind"), require("../Navigation/Tabs/Tabs.tailwind"), require("../Layout/Tables/DataTable/DataTable.tailwind"), require("../Layout/Tables/Table/Table.tailwind"), require("../Indicators/Tag/Tag.tailwind"), require("../Fields/TextArea/TextArea.tailwind"), require("../Fields/Toggle/Toggle.tailwind"), require("../Overlay/Tooltip/Tooltip.tailwind"), require("../Helpers/UserContent/UserContent.tailwind"), require("../Fields/DatePicker/DatePicker.tailwind")]
|
145
145
|
};
|
@@ -1,27 +1,14 @@
|
|
1
|
+
/// <reference types="react" />
|
1
2
|
import type { ToggleProps } from "@radix-ui/react-toggle";
|
2
|
-
import type {
|
3
|
-
|
4
|
-
import type { ButtonSize } from "../Button/types";
|
5
|
-
declare type InputElementProps = InputHTMLAttributes<HTMLInputElement>;
|
6
|
-
declare type ToggleButtonSharedProps = {
|
7
|
-
id?: InputElementProps["id"];
|
8
|
-
className?: InputElementProps["className"];
|
9
|
-
style?: InputElementProps["style"];
|
10
|
-
autoFocus?: InputElementProps["autoFocus"];
|
11
|
-
disabled?: InputElementProps["disabled"];
|
3
|
+
import type { ToggleButtonBaseProps } from "./ToggleButtonBase";
|
4
|
+
export declare type ToggleButtonProps = {
|
12
5
|
pressed?: ToggleProps["pressed"];
|
13
6
|
defaultPressed?: ToggleProps["defaultPressed"];
|
14
7
|
onPressedChange?: ToggleProps["onPressedChange"];
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
declare type TextToggleButtonProps = {
|
22
|
-
icon?: IconComponentType;
|
23
|
-
children: ReactNode;
|
24
|
-
};
|
25
|
-
export declare type ToggleButtonProps = ToggleButtonSharedProps & (IconOnlyToggleButtonProps | TextToggleButtonProps);
|
8
|
+
} & ToggleButtonBaseProps;
|
9
|
+
/**
|
10
|
+
* The `ToggleButton` component is a button that toggles between two states.
|
11
|
+
*
|
12
|
+
* See the [ToggleButton documentation page](https://satellite.algolia.com/components/actions/toggle-button) for more information.
|
13
|
+
*/
|
26
14
|
export declare const ToggleButton: import("react").ForwardRefExoticComponent<ToggleButtonProps & import("react").RefAttributes<HTMLButtonElement>>;
|
27
|
-
export {};
|
@@ -1,49 +1,36 @@
|
|
1
1
|
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
2
2
|
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
|
3
|
-
|
4
|
-
var _excluded = ["className", "size", "icon", "children", "label"];
|
5
|
-
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10;
|
3
|
+
var _excluded = ["size", "icon", "children", "label"];
|
6
4
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
7
5
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
8
6
|
import { Toggle } from "@radix-ui/react-toggle";
|
9
|
-
import cx from "clsx";
|
10
7
|
import { forwardRef } from "react";
|
11
|
-
import {
|
12
|
-
import
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
large: stl(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["h-10 w-10"])))
|
19
|
-
};
|
8
|
+
import { ToggleButtonBase } from "./ToggleButtonBase";
|
9
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
10
|
+
/**
|
11
|
+
* The `ToggleButton` component is a button that toggles between two states.
|
12
|
+
*
|
13
|
+
* See the [ToggleButton documentation page](https://satellite.algolia.com/components/actions/toggle-button) for more information.
|
14
|
+
*/
|
20
15
|
export var ToggleButton = /*#__PURE__*/forwardRef(function (props, ref) {
|
21
|
-
var isIconOnly = !props.children;
|
22
16
|
var _label$props = _objectSpread({
|
23
17
|
label: undefined
|
24
18
|
}, props),
|
25
|
-
|
26
|
-
|
27
|
-
size = _label$props$size === void 0 ? "medium" : _label$props$size,
|
28
|
-
Icon = _label$props.icon,
|
19
|
+
size = _label$props.size,
|
20
|
+
icon = _label$props.icon,
|
29
21
|
children = _label$props.children,
|
30
22
|
label = _label$props.label,
|
31
23
|
rest = _objectWithoutProperties(_label$props, _excluded);
|
32
|
-
return /*#__PURE__*/_jsx(
|
33
|
-
|
34
|
-
|
24
|
+
return /*#__PURE__*/_jsx(Toggle, _objectSpread(_objectSpread({
|
25
|
+
asChild: true
|
26
|
+
}, rest), {}, {
|
27
|
+
children: /*#__PURE__*/_jsx(ToggleButtonBase, {
|
35
28
|
ref: ref,
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
className: stl(_templateObject10 || (_templateObject10 = _taggedTemplateLiteral(["shrink-0 h-4 w-4 text-grey-600 group-aria-pressed/toggle-button:text-inherit group-disabled/toggle-button:text-inherit"])))
|
43
|
-
}), !!children && /*#__PURE__*/_jsx("div", {
|
44
|
-
children: children
|
45
|
-
})]
|
46
|
-
}))
|
47
|
-
});
|
29
|
+
size: size,
|
30
|
+
icon: icon,
|
31
|
+
label: label,
|
32
|
+
children: children
|
33
|
+
})
|
34
|
+
}));
|
48
35
|
});
|
49
36
|
ToggleButton.displayName = "ToggleButton";
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import type { ButtonHTMLAttributes, ReactNode } from "react";
|
2
|
+
import type { IconComponentType } from "../../Icons";
|
3
|
+
import type { ButtonSize } from "../Button/types";
|
4
|
+
declare type IconOnlyToggleButtonBaseProps = {
|
5
|
+
icon: IconComponentType;
|
6
|
+
label: string;
|
7
|
+
};
|
8
|
+
declare type TextToggleButtonBaseProps = {
|
9
|
+
icon?: IconComponentType;
|
10
|
+
children: ReactNode;
|
11
|
+
};
|
12
|
+
export declare type ToggleButtonBaseProps = Pick<ButtonHTMLAttributes<HTMLButtonElement>, "id" | "className" | "style" | "autoFocus" | "disabled"> & {
|
13
|
+
size?: ButtonSize;
|
14
|
+
} & (IconOnlyToggleButtonBaseProps | TextToggleButtonBaseProps);
|
15
|
+
export declare const ToggleButtonBase: import("react").ForwardRefExoticComponent<ToggleButtonBaseProps & import("react").RefAttributes<HTMLButtonElement>>;
|
16
|
+
export {};
|