namirasoft-site-react 1.3.180 → 1.3.182
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/App.js +4 -4
- package/dist/App.js.map +1 -1
- package/dist/components/NSActionMenu.d.ts +8 -8
- package/dist/components/NSActionMenu.js +7 -6
- package/dist/components/NSActionMenu.js.map +1 -1
- package/dist/components/NSBarAction.d.ts +3 -1
- package/dist/components/NSBarAction.js +2 -2
- package/dist/components/NSBarAction.js.map +1 -1
- package/dist/components/NSBox.module.css +21 -1
- package/dist/components/NSBoxEmail.d.ts +1 -0
- package/dist/components/NSBoxEmail.js +5 -1
- package/dist/components/NSBoxEmail.js.map +1 -1
- package/package.json +4 -3
- package/src/App.tsx +8 -10
- package/src/components/NSActionMenu.tsx +39 -44
- package/src/components/NSBarAction.tsx +9 -10
- package/src/components/NSBox.module.css +21 -1
- package/src/components/NSBoxEmail.tsx +12 -1
package/dist/App.js
CHANGED
|
@@ -15,9 +15,9 @@ export function App() {
|
|
|
15
15
|
{ src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
|
|
16
16
|
{ src: "https://static.namirasoft.com/image/concept/logout/white.svg", alt: "", onClicked },
|
|
17
17
|
];
|
|
18
|
-
return (_jsx(_Fragment, { children: _jsx(NSLayout, {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
}, logo:
|
|
18
|
+
return (_jsx(_Fragment, { children: _jsx(NSLayout, { header: {
|
|
19
|
+
title: "any",
|
|
20
|
+
icons: icons
|
|
21
|
+
}, scope: "exampleScope", logo: "exampleLogoUrl", notifications: [], background: "", children: _jsx(_Fragment, {}) }) }));
|
|
22
22
|
}
|
|
23
23
|
//# sourceMappingURL=App.js.map
|
package/dist/App.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"App.js","sourceRoot":"","sources":["../src/App.tsx"],"names":[],"mappings":";AAAA,OAAO,WAAW,CAAC;AACnB,OAAO,sCAAsC,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAElC,MAAM,UAAU,GAAG;IAGlB,MAAM,SAAS,GAAG,GAAG,EAAE;QAEtB,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;IACvB,CAAC,CAAA;IAED,IAAI,KAAK,GAAG;QACX,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE;QACrG,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;QAC3F,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;QAC3F,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;QAC3F,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;QAC3F,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;QAC3F,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;KAC3F,CAAC;IAEF,OAAO,CACN,4BACC,KAAC,QAAQ,IACR,
|
|
1
|
+
{"version":3,"file":"App.js","sourceRoot":"","sources":["../src/App.tsx"],"names":[],"mappings":";AAAA,OAAO,WAAW,CAAC;AACnB,OAAO,sCAAsC,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAElC,MAAM,UAAU,GAAG;IAGlB,MAAM,SAAS,GAAG,GAAG,EAAE;QAEtB,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;IACvB,CAAC,CAAA;IAED,IAAI,KAAK,GAAG;QACX,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE;QACrG,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;QAC3F,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;QAC3F,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;QAC3F,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;QAC3F,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;QAC3F,EAAE,GAAG,EAAE,8DAA8D,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE;KAC3F,CAAC;IAEF,OAAO,CACN,4BACC,KAAC,QAAQ,IACR,MAAM,EAAE;gBACP,KAAK,EAAE,KAAK;gBACZ,KAAK,EAAE,KAAK;aACZ,EACD,KAAK,EAAC,cAAc,EACpB,IAAI,EAAC,gBAAgB,EACrB,aAAa,EAAE,EAAE,EACjB,UAAU,EAAC,EAAE,YAEb,mBAAK,GACK,GACT,CACH,CAAC;AACH,CAAC"}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { IBaseComponentProps } from '../main';
|
|
2
2
|
export interface INSActionMenuProps extends IBaseComponentProps {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
handler: () => void;
|
|
8
|
-
isActive: () => boolean;
|
|
9
|
-
}[];
|
|
3
|
+
id: string;
|
|
4
|
+
menu_item: string;
|
|
5
|
+
handler: () => void;
|
|
6
|
+
isActive: () => boolean;
|
|
10
7
|
}
|
|
11
8
|
export interface INSActionMenuState {
|
|
12
9
|
isShow: boolean;
|
|
13
10
|
}
|
|
14
|
-
export declare function NSActionMenu(props:
|
|
11
|
+
export declare function NSActionMenu(props: {
|
|
12
|
+
name: string;
|
|
13
|
+
items: INSActionMenuProps[];
|
|
14
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Fragment as _Fragment, jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { useState, useEffect, useRef } from 'react';
|
|
3
3
|
import { NSButtonBlue } from '../main';
|
|
4
4
|
import Styles from './NSActionMenu.module.css';
|
|
@@ -18,11 +18,12 @@ export function NSActionMenu(props) {
|
|
|
18
18
|
document.removeEventListener('mousedown', handleClickOutside);
|
|
19
19
|
};
|
|
20
20
|
}, [menuRef]);
|
|
21
|
-
|
|
22
|
-
|
|
21
|
+
if (props.items.length == 0)
|
|
22
|
+
return _jsx(_Fragment, {});
|
|
23
|
+
if (props.items.length == 1)
|
|
24
|
+
return _jsx(NSButtonBlue, { title: props.items[0].menu_item, onClick: props.items[0].handler });
|
|
25
|
+
return (_jsxs("div", { className: Styles.ns_action_bar, ref: menuRef, children: [_jsxs("button", { onClick: () => setState((prevState) => (Object.assign(Object.assign({}, prevState), { isShow: !state.isShow }))), children: [props.name, _jsx("img", { className: Styles.ns_action_menu_icon, src: "https://static.namirasoft.com/image/concept/ellipsis/vertical-blue.png", alt: "Icon", width: 8, height: 24 })] }), _jsx("ul", { className: `${Styles.ns_action_item_holder} ${state.isShow ? Styles.ns_show : Styles.ns_hide}`, children: props.items.map((item) => _jsx("li", { onClick: item.handler, className: `${Styles.ns_action_item}
|
|
23
26
|
${item.isActive() ? Styles.ns_active_item : Styles.ns_deActive_item}
|
|
24
|
-
`, children: item.menu_item }, item.id)) })] })
|
|
25
|
-
:
|
|
26
|
-
_jsx(_Fragment, { children: _jsx(NSButtonBlue, { title: props.items[0].menu_item, onClick: props.items[0].handler }) }) }));
|
|
27
|
+
`, children: item.menu_item }, item.id)) })] }));
|
|
27
28
|
}
|
|
28
29
|
//# sourceMappingURL=NSActionMenu.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NSActionMenu.js","sourceRoot":"","sources":["../../src/components/NSActionMenu.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AACpD,OAAO,EAAuB,YAAY,EAAE,MAAM,SAAS,CAAC;AAC5D,OAAO,MAAM,MAAM,2BAA2B,CAAC;
|
|
1
|
+
{"version":3,"file":"NSActionMenu.js","sourceRoot":"","sources":["../../src/components/NSActionMenu.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AACpD,OAAO,EAAuB,YAAY,EAAE,MAAM,SAAS,CAAC;AAC5D,OAAO,MAAM,MAAM,2BAA2B,CAAC;AAe/C,MAAM,UAAU,YAAY,CAAC,KAAoD;IAEhF,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAqB;QACtD,MAAM,EAAE,KAAK;KACb,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;IAE7C,SAAS,CAAC,GAAG,EAAE;QAEd,SAAS,kBAAkB,CAAC,KAAiB;YAE5C,IAAI,OAAO,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAc,CAAC,EACtE;gBACC,QAAQ,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;aAC5B;QACF,CAAC;QAED,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,kBAAkB,CAAC,CAAC;QAC3D,OAAO,GAAG,EAAE;YAEX,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,kBAAkB,CAAC,CAAC;QAC/D,CAAC,CAAC;IACH,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEd,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC;QAC1B,OAAO,mBAAK,CAAC;IACd,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC;QAC1B,OAAO,KAAC,YAAY,IACnB,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,EAC/B,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,GAC9B,CAAC;IACJ,OAAO,CACN,eAAK,SAAS,EAAE,MAAM,CAAC,aAAa,EAAE,GAAG,EAAE,OAAO,aACjD,kBAAQ,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,iCAC3C,SAAS,KAAE,MAAM,EAAE,CAAC,KAAK,CAAC,MAAM,IAClC,CAAC,aACD,KAAK,CAAC,IAAI,EACX,cACC,SAAS,EAAE,MAAM,CAAC,mBAAmB,EACrC,GAAG,EAAC,wEAAwE,EAC5E,GAAG,EAAC,MAAM,EACV,KAAK,EAAE,CAAC,EACR,MAAM,EAAE,EAAE,GACT,IACM,EACT,aAAI,SAAS,EAAE,GAAG,MAAM,CAAC,qBAAqB,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,YAEhG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CACxB,aAEC,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,SAAS,EAAE,GAAG,MAAM,CAAC,cAAc;UAChC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC,gBAAgB;SAClE,YAED,IAAI,CAAC,SAAS,IANV,IAAI,CAAC,EAAE,CAOR,CACL,GAEE,IACA,CACN,CAAC;AACH,CAAC"}
|
|
@@ -2,7 +2,9 @@ import { INSActionMenuProps } from './NSActionMenu';
|
|
|
2
2
|
export interface INSBarActionProps {
|
|
3
3
|
title: string;
|
|
4
4
|
description?: string;
|
|
5
|
-
menus:
|
|
5
|
+
menus: {
|
|
6
|
+
[group: string]: INSActionMenuProps[];
|
|
7
|
+
};
|
|
6
8
|
}
|
|
7
9
|
export interface NSBarActionState {
|
|
8
10
|
show: boolean;
|
|
@@ -10,9 +10,9 @@ export function NSBarAction(props) {
|
|
|
10
10
|
const [state, setState] = useState({
|
|
11
11
|
show: false
|
|
12
12
|
});
|
|
13
|
-
const
|
|
13
|
+
const groups = Object.keys(props.menus);
|
|
14
14
|
return (_jsxs(_Fragment, { children: [_jsxs("div", { className: Styles.ns_action_bar_holder, children: [_jsxs("div", { className: `d-none d-lg-flex ${Styles.ns_desktop_action_bar_title}`, children: [_jsx("h1", { className: Styles.title, children: props.title }), props.description !== "" &&
|
|
15
|
-
_jsxs("button", { className: Styles.ns_info_container, onClick: () => setState({ show: true }), children: [_jsx("img", { src: 'https://static.namirasoft.com/image/concept/info/white-blue.svg', alt: 'info-icon', width: 24, height: 24 }), _jsx("span", { children: " Info " })] }), _jsx(NSModal, { show: state.show, description: props.description, title: props.title, onClose: () => setState({ show: false }) })] }), _jsx("div", { style: { padding:
|
|
15
|
+
_jsxs("button", { className: Styles.ns_info_container, onClick: () => setState({ show: true }), children: [_jsx("img", { src: 'https://static.namirasoft.com/image/concept/info/white-blue.svg', alt: 'info-icon', width: 24, height: 24 }), _jsx("span", { children: " Info " })] }), _jsx(NSModal, { show: state.show, description: props.description, title: props.title, onClose: () => setState({ show: false }) })] }), _jsx("div", { style: { padding: groups.length !== 0 ? "16px 0" : "0" }, className: Styles.ns_actions_hodler, children: groups.map((group) => _jsx(NSActionMenu, { name: group, items: props.menus[group] })) })] }), _jsx(NSSpace, { size: NSSpaceSizeType.SMALL }), _jsxs("div", { className: `container d-block d-lg-none ${Styles.ns_mobile_action_bar_title}`, children: [_jsx("h1", { className: Styles.title, children: props.title }), props.description && lines &&
|
|
16
16
|
_jsxs(_Fragment, { children: [_jsx("p", { className: Styles.description, children: lines.map((line, index) => {
|
|
17
17
|
return (_jsxs(React.Fragment, { children: [line.trim(), index !== lines.length - 1 && _jsx("br", {})] }, index));
|
|
18
18
|
}) }), _jsx(NSSpace, { size: NSSpaceSizeType.MINI })] })] })] }));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NSBarAction.js","sourceRoot":"","sources":["../../src/components/NSBarAction.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AACrD,OAAO,MAAM,MAAM,0BAA0B,CAAC;AAC9C,OAAO,EAAsB,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAcpC,MAAM,UAAU,WAAW,CAAC,KAAwB;;IAEnD,IAAI,KAAK,GAAG,CAAC,MAAA,KAAK,CAAC,WAAW,mCAAI,EAAE,CAAC,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"NSBarAction.js","sourceRoot":"","sources":["../../src/components/NSBarAction.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AACrD,OAAO,MAAM,MAAM,0BAA0B,CAAC;AAC9C,OAAO,EAAsB,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAcpC,MAAM,UAAU,WAAW,CAAC,KAAwB;;IAEnD,IAAI,KAAK,GAAG,CAAC,MAAA,KAAK,CAAC,WAAW,mCAAI,EAAE,CAAC,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;IAEzE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAmB;QACpD,IAAI,EAAE,KAAK;KACX,CAAC,CAAA;IAEF,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAExC,OAAO,CACN,8BACC,eAAK,SAAS,EAAE,MAAM,CAAC,oBAAoB,aAE1C,eAAK,SAAS,EAAE,oBAAoB,MAAM,CAAC,2BAA2B,EAAE,aACvE,aAAI,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,CAAC,KAAK,GAAM,EAE9C,KAAK,CAAC,WAAW,KAAK,EAAE;gCACxB,kBAAQ,SAAS,EAAE,MAAM,CAAC,iBAAiB,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,aACnF,cAAK,GAAG,EAAC,iEAAiE,EAAC,GAAG,EAAC,WAAW,EAAC,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,GAAI,EACpH,oCAAmB,IACX,EAEV,KAAC,OAAO,IACP,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,WAAW,EAAE,KAAK,CAAC,WAAW,EAC9B,KAAK,EAAE,KAAK,CAAC,KAAK,EAClB,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,GACvC,IACG,EACN,cACC,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,EACxD,SAAS,EAAE,MAAM,CAAC,iBAAiB,YAGlC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACpB,KAAC,YAAY,IAAC,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAI,CACxD,GAEG,IACD,EACN,KAAC,OAAO,IAAC,IAAI,EAAE,eAAe,CAAC,KAAK,GAAI,EAExC,eAAK,SAAS,EAAE,+BAA+B,MAAM,CAAC,0BAA0B,EAAE,aACjF,aAAI,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,CAAC,KAAK,GAAM,EAE9C,KAAK,CAAC,WAAW,IAAI,KAAK;wBAC1B,8BACC,YAAG,SAAS,EAAE,MAAM,CAAC,WAAW,YAE9B,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;wCAEzB,OAAO,CACN,MAAC,KAAK,CAAC,QAAQ,eACb,IAAI,CAAC,IAAI,EAAE,EACX,KAAK,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,cAAM,KAFjB,KAAK,CAGT,CACjB,CAAA;oCACF,CAAC,CAAC,GAEA,EACJ,KAAC,OAAO,IAAC,IAAI,EAAE,eAAe,CAAC,IAAI,GAAI,IACrC,IAEC,IACJ,CACH,CAAC;AACH,CAAC"}
|
|
@@ -48,6 +48,8 @@
|
|
|
48
48
|
.ns_input_title {
|
|
49
49
|
font-size: 16px;
|
|
50
50
|
font-weight: 400;
|
|
51
|
+
display: flex;
|
|
52
|
+
align-items: center;
|
|
51
53
|
}
|
|
52
54
|
|
|
53
55
|
@media only screen and (min-width: 380px) {
|
|
@@ -73,5 +75,23 @@
|
|
|
73
75
|
width: 272px !important;
|
|
74
76
|
}
|
|
75
77
|
}
|
|
78
|
+
/*End Input phone*/
|
|
79
|
+
|
|
80
|
+
.ns_btn_box {
|
|
81
|
+
opacity: 0;
|
|
82
|
+
visibility: hidden;
|
|
83
|
+
background-color: #007bff;
|
|
84
|
+
color: white;
|
|
85
|
+
border: none;
|
|
86
|
+
padding: 4px 10px;
|
|
87
|
+
border-radius: 8px;
|
|
88
|
+
cursor: pointer;
|
|
89
|
+
width: max-content;
|
|
90
|
+
margin: 5px 0;
|
|
91
|
+
}
|
|
76
92
|
|
|
77
|
-
|
|
93
|
+
.ns_input_parent:hover .ns_btn_box {
|
|
94
|
+
opacity: 1;
|
|
95
|
+
visibility: visible;
|
|
96
|
+
transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
|
|
97
|
+
}
|
|
@@ -13,6 +13,7 @@ export class NSBoxEmail extends React.Component {
|
|
|
13
13
|
this.setValue = this.setValue.bind(this);
|
|
14
14
|
this.getValue = this.getValue.bind(this);
|
|
15
15
|
this.onChanged = this.onChanged.bind(this);
|
|
16
|
+
this.copyToClipboard = this.copyToClipboard.bind(this);
|
|
16
17
|
}
|
|
17
18
|
getError() {
|
|
18
19
|
return (Validator.getError(this.props.title, this.state.value, this.props) &&
|
|
@@ -35,9 +36,12 @@ export class NSBoxEmail extends React.Component {
|
|
|
35
36
|
if (this.props.onChanged)
|
|
36
37
|
this.props.onChanged(e);
|
|
37
38
|
}
|
|
39
|
+
copyToClipboard() {
|
|
40
|
+
navigator.clipboard.writeText(this.getValue());
|
|
41
|
+
}
|
|
38
42
|
render() {
|
|
39
43
|
var _a;
|
|
40
|
-
return (_jsxs(_Fragment, { children: [_jsxs("div", { className: `${Styles.ns_input_parent} ${(_a = this.props.classList) === null || _a === void 0 ? void 0 : _a.join(" ")}`, style: this.props.style, children: [_jsxs("span", { className: Styles.ns_input_title, children: [" ", this.props.required && _jsx("span", { style: { color: "red" }, children: "*" }), " ", this.props.title, " "] }), _jsx("img", { className: Styles.ns_input_icon, src: IconInputEmail, alt: "Email Icon", width: 24, height: 24 }), _jsx("input", { id: this.props.id, value: this.state.value, onChange: this.onChanged, type: "email", className: Styles.ns_input, placeholder: this.props.placeholder })] }), _jsx(NSBoxErrorNotifier, { error: this.state.error })] }));
|
|
44
|
+
return (_jsxs(_Fragment, { children: [_jsxs("div", { className: `${Styles.ns_input_parent} ${(_a = this.props.classList) === null || _a === void 0 ? void 0 : _a.join(" ")}`, style: this.props.style, children: [_jsxs("div", { className: "d-flex justify-content-between align-item-center", children: [_jsxs("span", { className: Styles.ns_input_title, children: [" ", this.props.required && _jsx("span", { style: { color: "red" }, children: "*" }), " ", this.props.title, " "] }), _jsxs("div", { className: "d-flex gap-2", children: [_jsx("button", { className: Styles.ns_btn_box, onClick: this.copyToClipboard, children: "Copy" }), _jsx("button", { className: Styles.ns_btn_box, onClick: () => { }, children: "FullScreen" })] })] }), _jsx("img", { className: Styles.ns_input_icon, src: IconInputEmail, alt: "Email Icon", width: 24, height: 24 }), _jsx("input", { id: this.props.id, value: this.state.value, onChange: this.onChanged, type: "email", className: Styles.ns_input, placeholder: this.props.placeholder })] }), _jsx(NSBoxErrorNotifier, { error: this.state.error })] }));
|
|
41
45
|
}
|
|
42
46
|
}
|
|
43
47
|
//# sourceMappingURL=NSBoxEmail.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NSBoxEmail.js","sourceRoot":"","sources":["../../src/components/NSBoxEmail.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AACxC,OAAO,cAAc,MAAM,uCAAuC,CAAC;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAIzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAgB1D,MAAM,OAAO,UAAW,SAAQ,KAAK,CAAC,SAA6C;IAElF,YAAY,KAAuB;;QAElC,KAAK,CAAC,KAAK,CAAC,CAAC;QACb,IAAI,CAAC,KAAK,GAAG,EAAE,KAAK,EAAE,MAAA,KAAK,CAAC,YAAY,mCAAI,EAAE,EAAE,CAAC;QACjD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"NSBoxEmail.js","sourceRoot":"","sources":["../../src/components/NSBoxEmail.tsx"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -8,11 +8,11 @@
|
|
|
8
8
|
"framework": "npm",
|
|
9
9
|
"application": "package",
|
|
10
10
|
"private": false,
|
|
11
|
-
"version": "1.3.
|
|
11
|
+
"version": "1.3.182",
|
|
12
12
|
"author": "Amir Abolhasani, Alireza Esmaeeli, Sepideh Mazloumi, Hooman Shashaeh",
|
|
13
13
|
"license": "MIT",
|
|
14
|
-
"main": "./dist/
|
|
15
|
-
"types": "./dist/
|
|
14
|
+
"main": "./dist/index.js",
|
|
15
|
+
"types": "./dist/index.d.ts",
|
|
16
16
|
"scripts": {
|
|
17
17
|
"start": "react-app-rewired start",
|
|
18
18
|
"build": "npm run copy",
|
|
@@ -20,6 +20,7 @@
|
|
|
20
20
|
"eject": "react-app-rewired eject",
|
|
21
21
|
"copy": "copyfiles -u 1 src/**/*.html src/**/*.css src/**/*.svg src/**/*.png src/**/*.jpg dist/"
|
|
22
22
|
},
|
|
23
|
+
|
|
23
24
|
"dependencies": {
|
|
24
25
|
"@types/node": "^20.14.2",
|
|
25
26
|
"@types/react": "^18.3.3",
|
package/src/App.tsx
CHANGED
|
@@ -23,18 +23,16 @@ export function App()
|
|
|
23
23
|
return (
|
|
24
24
|
<>
|
|
25
25
|
<NSLayout
|
|
26
|
-
|
|
26
|
+
header={{
|
|
27
|
+
title: "any",
|
|
28
|
+
icons: icons
|
|
29
|
+
}}
|
|
30
|
+
scope="exampleScope"
|
|
31
|
+
logo="exampleLogoUrl"
|
|
27
32
|
notifications={[]}
|
|
28
|
-
|
|
29
|
-
{
|
|
30
|
-
icons: icons,
|
|
31
|
-
title: "any"
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
logo=''
|
|
33
|
+
background=""
|
|
35
34
|
>
|
|
36
|
-
|
|
37
|
-
</>
|
|
35
|
+
<></>
|
|
38
36
|
</NSLayout>
|
|
39
37
|
</>
|
|
40
38
|
);
|
|
@@ -4,13 +4,10 @@ import Styles from './NSActionMenu.module.css';
|
|
|
4
4
|
|
|
5
5
|
export interface INSActionMenuProps extends IBaseComponentProps
|
|
6
6
|
{
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
handler: () => void;
|
|
12
|
-
isActive: () => boolean;
|
|
13
|
-
}[];
|
|
7
|
+
id: string
|
|
8
|
+
menu_item: string;
|
|
9
|
+
handler: () => void;
|
|
10
|
+
isActive: () => boolean;
|
|
14
11
|
}
|
|
15
12
|
|
|
16
13
|
export interface INSActionMenuState
|
|
@@ -18,7 +15,7 @@ export interface INSActionMenuState
|
|
|
18
15
|
isShow: boolean;
|
|
19
16
|
}
|
|
20
17
|
|
|
21
|
-
export function NSActionMenu(props: INSActionMenuProps)
|
|
18
|
+
export function NSActionMenu(props: { name: string, items: INSActionMenuProps[] })
|
|
22
19
|
{
|
|
23
20
|
const [state, setState] = useState<INSActionMenuState>({
|
|
24
21
|
isShow: false
|
|
@@ -43,44 +40,42 @@ export function NSActionMenu(props: INSActionMenuProps)
|
|
|
43
40
|
};
|
|
44
41
|
}, [menuRef]);
|
|
45
42
|
|
|
43
|
+
if (props.items.length == 0)
|
|
44
|
+
return <></>;
|
|
45
|
+
if (props.items.length == 1)
|
|
46
|
+
return <NSButtonBlue
|
|
47
|
+
title={props.items[0].menu_item}
|
|
48
|
+
onClick={props.items[0].handler}
|
|
49
|
+
/>;
|
|
46
50
|
return (
|
|
47
|
-
|
|
48
|
-
{
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
className={`${Styles.ns_action_item}
|
|
51
|
+
<div className={Styles.ns_action_bar} ref={menuRef}>
|
|
52
|
+
<button onClick={() => setState((prevState) => ({
|
|
53
|
+
...prevState, isShow: !state.isShow
|
|
54
|
+
}))}>
|
|
55
|
+
{props.name}
|
|
56
|
+
<img
|
|
57
|
+
className={Styles.ns_action_menu_icon}
|
|
58
|
+
src="https://static.namirasoft.com/image/concept/ellipsis/vertical-blue.png"
|
|
59
|
+
alt="Icon"
|
|
60
|
+
width={8}
|
|
61
|
+
height={24}
|
|
62
|
+
/>
|
|
63
|
+
</button>
|
|
64
|
+
<ul className={`${Styles.ns_action_item_holder} ${state.isShow ? Styles.ns_show : Styles.ns_hide}`}>
|
|
65
|
+
{
|
|
66
|
+
props.items.map((item) =>
|
|
67
|
+
<li
|
|
68
|
+
key={item.id}
|
|
69
|
+
onClick={item.handler}
|
|
70
|
+
className={`${Styles.ns_action_item}
|
|
68
71
|
${item.isActive() ? Styles.ns_active_item : Styles.ns_deActive_item}
|
|
69
72
|
`}
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
<>
|
|
78
|
-
<NSButtonBlue
|
|
79
|
-
title={props.items[0].menu_item}
|
|
80
|
-
onClick={props.items[0].handler}
|
|
81
|
-
/>
|
|
82
|
-
</>
|
|
83
|
-
}
|
|
84
|
-
</>
|
|
73
|
+
>
|
|
74
|
+
{item.menu_item}
|
|
75
|
+
</li>
|
|
76
|
+
)
|
|
77
|
+
}
|
|
78
|
+
</ul>
|
|
79
|
+
</div>
|
|
85
80
|
);
|
|
86
81
|
}
|
|
@@ -8,7 +8,7 @@ export interface INSBarActionProps
|
|
|
8
8
|
{
|
|
9
9
|
title: string;
|
|
10
10
|
description?: string;
|
|
11
|
-
menus: INSActionMenuProps[];
|
|
11
|
+
menus: { [group: string]: INSActionMenuProps[] };
|
|
12
12
|
}
|
|
13
13
|
|
|
14
14
|
export interface NSBarActionState
|
|
@@ -19,11 +19,12 @@ export interface NSBarActionState
|
|
|
19
19
|
export function NSBarAction(props: INSBarActionProps)
|
|
20
20
|
{
|
|
21
21
|
let lines = (props.description ?? "").split(/(\n|\\n|<br>|<br\s*\/>)/gm);
|
|
22
|
+
|
|
22
23
|
const [state, setState] = useState<NSBarActionState>({
|
|
23
24
|
show: false
|
|
24
25
|
})
|
|
25
26
|
|
|
26
|
-
const
|
|
27
|
+
const groups = Object.keys(props.menus);
|
|
27
28
|
|
|
28
29
|
return (
|
|
29
30
|
<>
|
|
@@ -46,16 +47,14 @@ export function NSBarAction(props: INSBarActionProps)
|
|
|
46
47
|
/>
|
|
47
48
|
</div>
|
|
48
49
|
<div
|
|
49
|
-
style={{ padding:
|
|
50
|
+
style={{ padding: groups.length !== 0 ? "16px 0" : "0" }}
|
|
50
51
|
className={Styles.ns_actions_hodler}
|
|
51
52
|
>
|
|
52
|
-
{
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
/>
|
|
58
|
-
)}
|
|
53
|
+
{
|
|
54
|
+
groups.map((group) =>
|
|
55
|
+
<NSActionMenu name={group} items={props.menus[group]} />
|
|
56
|
+
)
|
|
57
|
+
}
|
|
59
58
|
</div>
|
|
60
59
|
</div>
|
|
61
60
|
<NSSpace size={NSSpaceSizeType.SMALL} />
|
|
@@ -48,6 +48,8 @@
|
|
|
48
48
|
.ns_input_title {
|
|
49
49
|
font-size: 16px;
|
|
50
50
|
font-weight: 400;
|
|
51
|
+
display: flex;
|
|
52
|
+
align-items: center;
|
|
51
53
|
}
|
|
52
54
|
|
|
53
55
|
@media only screen and (min-width: 380px) {
|
|
@@ -73,5 +75,23 @@
|
|
|
73
75
|
width: 272px !important;
|
|
74
76
|
}
|
|
75
77
|
}
|
|
78
|
+
/*End Input phone*/
|
|
79
|
+
|
|
80
|
+
.ns_btn_box {
|
|
81
|
+
opacity: 0;
|
|
82
|
+
visibility: hidden;
|
|
83
|
+
background-color: #007bff;
|
|
84
|
+
color: white;
|
|
85
|
+
border: none;
|
|
86
|
+
padding: 4px 10px;
|
|
87
|
+
border-radius: 8px;
|
|
88
|
+
cursor: pointer;
|
|
89
|
+
width: max-content;
|
|
90
|
+
margin: 5px 0;
|
|
91
|
+
}
|
|
76
92
|
|
|
77
|
-
|
|
93
|
+
.ns_input_parent:hover .ns_btn_box {
|
|
94
|
+
opacity: 1;
|
|
95
|
+
visibility: visible;
|
|
96
|
+
transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
|
|
97
|
+
}
|
|
@@ -32,6 +32,7 @@ export class NSBoxEmail extends React.Component<INSBoxEmailProps, INSBoxEmailSta
|
|
|
32
32
|
this.setValue = this.setValue.bind(this);
|
|
33
33
|
this.getValue = this.getValue.bind(this);
|
|
34
34
|
this.onChanged = this.onChanged.bind(this);
|
|
35
|
+
this.copyToClipboard = this.copyToClipboard.bind(this);
|
|
35
36
|
}
|
|
36
37
|
getError(): string | null
|
|
37
38
|
{
|
|
@@ -61,12 +62,22 @@ export class NSBoxEmail extends React.Component<INSBoxEmailProps, INSBoxEmailSta
|
|
|
61
62
|
if (this.props.onChanged)
|
|
62
63
|
this.props.onChanged(e);
|
|
63
64
|
}
|
|
65
|
+
private copyToClipboard(): void
|
|
66
|
+
{
|
|
67
|
+
navigator.clipboard.writeText(this.getValue());
|
|
68
|
+
}
|
|
64
69
|
override render()
|
|
65
70
|
{
|
|
66
71
|
return (
|
|
67
72
|
<>
|
|
68
73
|
<div className={`${Styles.ns_input_parent} ${this.props.classList?.join(" ")}`} style={this.props.style}>
|
|
69
|
-
<
|
|
74
|
+
<div className="d-flex justify-content-between align-item-center">
|
|
75
|
+
<span className={Styles.ns_input_title}> {this.props.required && <span style={{ color: "red" }} >*</span>} {this.props.title} </span>
|
|
76
|
+
<div className="d-flex gap-2">
|
|
77
|
+
<button className={Styles.ns_btn_box} onClick={this.copyToClipboard}>Copy</button>
|
|
78
|
+
<button className={Styles.ns_btn_box} onClick={() => { }}>FullScreen</button>
|
|
79
|
+
</div>
|
|
80
|
+
</div>
|
|
70
81
|
<img
|
|
71
82
|
className={Styles.ns_input_icon}
|
|
72
83
|
src={IconInputEmail}
|