@bit.rhplus/ui2.collapsible-divider 0.0.1

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.
@@ -0,0 +1,3 @@
1
+ declare const _default: React.NamedExoticComponent<React.RefAttributes<any>>;
2
+ export default _default;
3
+ import React from 'react';
package/dist/index.js ADDED
@@ -0,0 +1,18 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ /* eslint-disable */
3
+ import React, { useState, useCallback, useMemo } from 'react';
4
+ import Button from 'antd/es/button';
5
+ import { DownOutlined, UpOutlined } from '@ant-design/icons';
6
+ import './style.css';
7
+ const CollapsibleDivider = React.forwardRef(({ title = 'Zobrazit', activeTitle = 'Skrýt', defaultOpen = false, children, style, ...restProps }, ref) => {
8
+ const [isOpen, setIsOpen] = useState(defaultOpen);
9
+ const handleToggle = useCallback(() => {
10
+ setIsOpen((prev) => !prev);
11
+ }, []);
12
+ const buttonText = isOpen ? activeTitle : title;
13
+ const ButtonIcon = isOpen ? UpOutlined : DownOutlined;
14
+ return (_jsxs("div", { className: "collapsible-divider", ref: ref, style: style, ...restProps, children: [_jsxs("div", { className: "collapsible-divider__header", children: [_jsx("div", { className: "collapsible-divider__line" }), _jsx("div", { className: "collapsible-divider__toggle", children: _jsx(Button, { shape: "round", size: "small", onClick: handleToggle, icon: _jsx(ButtonIcon, {}), children: buttonText }) }), _jsx("div", { className: "collapsible-divider__line" })] }), _jsx("div", { className: `collapsible-divider__content${isOpen ? '' : ' collapsible-divider__content--collapsed'}`, children: children })] }));
15
+ });
16
+ CollapsibleDivider.displayName = 'CollapsibleDivider';
17
+ export default React.memo(CollapsibleDivider);
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../index.jsx"],"names":[],"mappings":";AAAA,oBAAoB;AACpB,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAC9D,OAAO,MAAM,MAAM,gBAAgB,CAAC;AACpC,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,aAAa,CAAC;AAErB,MAAM,kBAAkB,GAAG,KAAK,CAAC,UAAU,CAAC,CAAC,EAC3C,KAAK,GAAG,UAAU,EAClB,WAAW,GAAG,OAAO,EACrB,WAAW,GAAG,KAAK,EACnB,QAAQ,EACR,KAAK,EACL,GAAG,SAAS,EACb,EAAE,GAAG,EAAE,EAAE;IACR,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,WAAW,CAAC,CAAC;IAElD,MAAM,YAAY,GAAG,WAAW,CAAC,GAAG,EAAE;QACpC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC;IAChD,MAAM,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC;IAEtD,OAAO,CACL,eAAK,SAAS,EAAC,qBAAqB,EAAC,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,KAAM,SAAS,aACxE,eAAK,SAAS,EAAC,6BAA6B,aAC1C,cAAK,SAAS,EAAC,2BAA2B,GAAG,EAC7C,cAAK,SAAS,EAAC,6BAA6B,YAC1C,KAAC,MAAM,IACL,KAAK,EAAC,OAAO,EACb,IAAI,EAAC,OAAO,EACZ,OAAO,EAAE,YAAY,EACrB,IAAI,EAAE,KAAC,UAAU,KAAG,YAEnB,UAAU,GACJ,GACL,EACN,cAAK,SAAS,EAAC,2BAA2B,GAAG,IACzC,EACN,cAAK,SAAS,EAAE,+BAA+B,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,0CAA0C,EAAE,YACtG,QAAQ,GACL,IACF,CACP,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,kBAAkB,CAAC,WAAW,GAAG,oBAAoB,CAAC;AAEtD,eAAe,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ ;
2
+ ;
3
+
4
+ export const compositions = [];
5
+ export const overview = [];
6
+
7
+ export const compositions_metadata = {"compositions":[]};
package/dist/style.css ADDED
@@ -0,0 +1,46 @@
1
+ .collapsible-divider {
2
+ margin: 16px 0;
3
+ }
4
+
5
+ .collapsible-divider__header {
6
+ display: flex;
7
+ align-items: center;
8
+ gap: 0;
9
+ width: 100%;
10
+ }
11
+
12
+ .collapsible-divider__line {
13
+ flex: 1;
14
+ height: 1px;
15
+ background-color: rgba(5, 5, 5, 0.06);
16
+ }
17
+
18
+ .collapsible-divider__toggle {
19
+ flex-shrink: 0;
20
+ }
21
+
22
+ .collapsible-divider__toggle .ant-btn {
23
+ font-size: 13px;
24
+ color: rgba(0, 0, 0, 0.45);
25
+ border-color: rgba(5, 5, 5, 0.06);
26
+ padding: 0 16px;
27
+ height: 28px;
28
+ }
29
+
30
+ .collapsible-divider__toggle .ant-btn:hover {
31
+ color: #1677ff;
32
+ border-color: #1677ff;
33
+ }
34
+
35
+ .collapsible-divider__content {
36
+ overflow: hidden;
37
+ transition: max-height 0.3s ease, opacity 0.3s ease;
38
+ opacity: 1;
39
+ max-height: 1000px;
40
+ margin-top: 16px;
41
+ }
42
+
43
+ .collapsible-divider__content--collapsed {
44
+ max-height: 0;
45
+ opacity: 0;
46
+ }
package/index.jsx ADDED
@@ -0,0 +1,49 @@
1
+ /* eslint-disable */
2
+ import React, { useState, useCallback, useMemo } from 'react';
3
+ import Button from 'antd/es/button';
4
+ import { DownOutlined, UpOutlined } from '@ant-design/icons';
5
+ import './style.css';
6
+
7
+ const CollapsibleDivider = React.forwardRef(({
8
+ title = 'Zobrazit',
9
+ activeTitle = 'Skrýt',
10
+ defaultOpen = false,
11
+ children,
12
+ style,
13
+ ...restProps
14
+ }, ref) => {
15
+ const [isOpen, setIsOpen] = useState(defaultOpen);
16
+
17
+ const handleToggle = useCallback(() => {
18
+ setIsOpen((prev) => !prev);
19
+ }, []);
20
+
21
+ const buttonText = isOpen ? activeTitle : title;
22
+ const ButtonIcon = isOpen ? UpOutlined : DownOutlined;
23
+
24
+ return (
25
+ <div className="collapsible-divider" ref={ref} style={style} {...restProps}>
26
+ <div className="collapsible-divider__header">
27
+ <div className="collapsible-divider__line" />
28
+ <div className="collapsible-divider__toggle">
29
+ <Button
30
+ shape="round"
31
+ size="small"
32
+ onClick={handleToggle}
33
+ icon={<ButtonIcon />}
34
+ >
35
+ {buttonText}
36
+ </Button>
37
+ </div>
38
+ <div className="collapsible-divider__line" />
39
+ </div>
40
+ <div className={`collapsible-divider__content${isOpen ? '' : ' collapsible-divider__content--collapsed'}`}>
41
+ {children}
42
+ </div>
43
+ </div>
44
+ );
45
+ });
46
+
47
+ CollapsibleDivider.displayName = 'CollapsibleDivider';
48
+
49
+ export default React.memo(CollapsibleDivider);
package/package.json ADDED
@@ -0,0 +1,29 @@
1
+ {
2
+ "name": "@bit.rhplus/ui2.collapsible-divider",
3
+ "version": "0.0.1",
4
+ "main": "dist/index.js",
5
+ "componentId": {
6
+ "name": "ui2/collapsible-divider",
7
+ "version": "0.0.1",
8
+ "scope": "remote-scope"
9
+ },
10
+ "dependencies": {
11
+ "@ant-design/icons": "^5.4.0",
12
+ "antd": "^5.20.6"
13
+ },
14
+ "devDependencies": {
15
+ "@bitdev/react.react-env": "5.0.5"
16
+ },
17
+ "peerDependencies": {
18
+ "react": "^17.0.0 || ^18.0.0 || ^19.0.0"
19
+ },
20
+ "license": "SEE LICENSE IN UNLICENSED",
21
+ "optionalDependencies": {},
22
+ "peerDependenciesMeta": {},
23
+ "type": "module",
24
+ "private": false,
25
+ "publishConfig": {
26
+ "scope": "@bit.rhplus",
27
+ "registry": "https://registry.npmjs.org/"
28
+ }
29
+ }
package/style.css ADDED
@@ -0,0 +1,46 @@
1
+ .collapsible-divider {
2
+ margin: 16px 0;
3
+ }
4
+
5
+ .collapsible-divider__header {
6
+ display: flex;
7
+ align-items: center;
8
+ gap: 0;
9
+ width: 100%;
10
+ }
11
+
12
+ .collapsible-divider__line {
13
+ flex: 1;
14
+ height: 1px;
15
+ background-color: rgba(5, 5, 5, 0.06);
16
+ }
17
+
18
+ .collapsible-divider__toggle {
19
+ flex-shrink: 0;
20
+ }
21
+
22
+ .collapsible-divider__toggle .ant-btn {
23
+ font-size: 13px;
24
+ color: rgba(0, 0, 0, 0.45);
25
+ border-color: rgba(5, 5, 5, 0.06);
26
+ padding: 0 16px;
27
+ height: 28px;
28
+ }
29
+
30
+ .collapsible-divider__toggle .ant-btn:hover {
31
+ color: #1677ff;
32
+ border-color: #1677ff;
33
+ }
34
+
35
+ .collapsible-divider__content {
36
+ overflow: hidden;
37
+ transition: max-height 0.3s ease, opacity 0.3s ease;
38
+ opacity: 1;
39
+ max-height: 1000px;
40
+ margin-top: 16px;
41
+ }
42
+
43
+ .collapsible-divider__content--collapsed {
44
+ max-height: 0;
45
+ opacity: 0;
46
+ }
@@ -0,0 +1,43 @@
1
+ declare module '*.png' {
2
+ const value: any;
3
+ export = value;
4
+ }
5
+ declare module '*.svg' {
6
+ import type { FunctionComponent, SVGProps } from 'react';
7
+
8
+ export const ReactComponent: FunctionComponent<
9
+ SVGProps<SVGSVGElement> & { title?: string }
10
+ >;
11
+ const src: string;
12
+ export default src;
13
+ }
14
+
15
+ // @TODO Gilad
16
+ declare module '*.jpg' {
17
+ const value: any;
18
+ export = value;
19
+ }
20
+ declare module '*.jpeg' {
21
+ const value: any;
22
+ export = value;
23
+ }
24
+ declare module '*.gif' {
25
+ const value: any;
26
+ export = value;
27
+ }
28
+ declare module '*.bmp' {
29
+ const value: any;
30
+ export = value;
31
+ }
32
+ declare module '*.otf' {
33
+ const value: any;
34
+ export = value;
35
+ }
36
+ declare module '*.woff' {
37
+ const value: any;
38
+ export = value;
39
+ }
40
+ declare module '*.woff2' {
41
+ const value: any;
42
+ export = value;
43
+ }
package/types/env.d.ts ADDED
@@ -0,0 +1,15 @@
1
+ /// <reference types="vite/client" />
2
+
3
+ export type ImportMetaEnv = Record<string, string>;
4
+
5
+ interface ImportMeta {
6
+ readonly env: ImportMetaEnv
7
+ }
8
+
9
+ declare global {
10
+ namespace NodeJS {
11
+ interface ProcessEnv {
12
+ [key: string]: string;
13
+ }
14
+ }
15
+ }
@@ -0,0 +1,42 @@
1
+ declare module '*.module.css' {
2
+ const classes: { readonly [key: string]: string };
3
+ export default classes;
4
+ }
5
+ declare module '*.module.scss' {
6
+ const classes: { readonly [key: string]: string };
7
+ export default classes;
8
+ }
9
+ declare module '*.module.sass' {
10
+ const classes: { readonly [key: string]: string };
11
+ export default classes;
12
+ }
13
+
14
+ declare module '*.module.less' {
15
+ const classes: { readonly [key: string]: string };
16
+ export default classes;
17
+ }
18
+
19
+ declare module '*.less' {
20
+ const classes: { readonly [key: string]: string };
21
+ export default classes;
22
+ }
23
+
24
+ declare module '*.css' {
25
+ const classes: { readonly [key: string]: string };
26
+ export default classes;
27
+ }
28
+
29
+ declare module '*.sass' {
30
+ const classes: { readonly [key: string]: string };
31
+ export default classes;
32
+ }
33
+
34
+ declare module '*.scss' {
35
+ const classes: { readonly [key: string]: string };
36
+ export default classes;
37
+ }
38
+
39
+ declare module '*.mdx' {
40
+ const component: any;
41
+ export default component;
42
+ }