@blaze-cms/react-page-builder 0.146.0-node18-core-styles-tooltips.11 → 0.146.0-node18-tooltips.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/CHANGELOG.md +6 -51
- package/lib/components/Menu/Menu.js +1 -4
- package/lib/components/Menu/Menu.js.map +1 -1
- package/lib/components/Menu/MenuContext.js +1 -2
- package/lib/components/Menu/MenuContext.js.map +1 -1
- package/lib/components/MenuItem/MenuItemRender.js +12 -27
- package/lib/components/MenuItem/MenuItemRender.js.map +1 -1
- package/lib/components/MenuItem/helpers/index.js +0 -14
- package/lib/components/MenuItem/helpers/index.js.map +1 -1
- package/lib/system-components/EditorMode/BlazeLogo.js +11 -4
- package/lib/system-components/EditorMode/BlazeLogo.js.map +1 -1
- package/lib/system-components/EditorMode/PbWrapper.js +12 -3
- package/lib/system-components/EditorMode/PbWrapper.js.map +1 -1
- package/lib-es/components/Menu/Menu.js +1 -4
- package/lib-es/components/Menu/Menu.js.map +1 -1
- package/lib-es/components/Menu/MenuContext.js +1 -2
- package/lib-es/components/Menu/MenuContext.js.map +1 -1
- package/lib-es/components/MenuItem/MenuItemRender.js +11 -25
- package/lib-es/components/MenuItem/MenuItemRender.js.map +1 -1
- package/lib-es/components/MenuItem/helpers/index.js +1 -3
- package/lib-es/components/MenuItem/helpers/index.js.map +1 -1
- package/lib-es/system-components/EditorMode/BlazeLogo.js +1 -1
- package/lib-es/system-components/EditorMode/BlazeLogo.js.map +1 -1
- package/lib-es/system-components/EditorMode/PbWrapper.js +1 -1
- package/lib-es/system-components/EditorMode/PbWrapper.js.map +1 -1
- package/package.json +10 -10
- package/src/components/Menu/Menu.js +1 -3
- package/src/components/Menu/MenuContext.js +1 -1
- package/src/components/MenuItem/MenuItemRender.js +12 -40
- package/src/components/MenuItem/helpers/index.js +1 -3
- package/src/system-components/EditorMode/BlazeLogo.js +19 -22
- package/src/system-components/EditorMode/PbWrapper.js +5 -8
- package/tests/unit/src/components/MenuItem/MenuItem.test.js +0 -5
- package/tests/unit/src/components/MenuItem/MenuItemRender.test.js +3 -11
- package/lib/components/MenuItem/helpers/has-active-child.js +0 -19
- package/lib/components/MenuItem/helpers/has-active-child.js.map +0 -1
- package/lib/components/MenuItem/helpers/isUrlPathMatch.js +0 -18
- package/lib/components/MenuItem/helpers/isUrlPathMatch.js.map +0 -1
- package/lib-es/components/MenuItem/helpers/has-active-child.js +0 -5
- package/lib-es/components/MenuItem/helpers/has-active-child.js.map +0 -1
- package/lib-es/components/MenuItem/helpers/isUrlPathMatch.js +0 -8
- package/lib-es/components/MenuItem/helpers/isUrlPathMatch.js.map +0 -1
- package/src/components/MenuItem/helpers/has-active-child.js +0 -10
- package/src/components/MenuItem/helpers/isUrlPathMatch.js +0 -10
- package/tests/unit/src/components/MenuItem/helpers/constants.js +0 -73
- package/tests/unit/src/components/MenuItem/helpers/has-active-child.test.js +0 -35
- package/tests/unit/src/components/MenuItem/helpers/is-url-path-match.test.js +0 -53
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Menu.js","names":["React","useState","useEffect","PropTypes","BlazeButton","classnames","useRouter","MdMenu","MdClose","Link","MenuContext","BlazeLink","Menu","children","collapse","
|
|
1
|
+
{"version":3,"file":"Menu.js","names":["React","useState","useEffect","PropTypes","BlazeButton","classnames","useRouter","MdMenu","MdClose","Link","MenuContext","BlazeLink","Menu","children","collapse","modifier","mobileMenuModifier","mobileMenuChildrenModifier","mobileIconAlignment","mobileButtonModifier","hamburgerIconModifier","logoOnMobile","logoOnDesktop","logoOnMobileUrl","logoOnMobileAlt","logoOnMobileModifier","logoOnDesktopModifier","closeIconModifier","router","showMobileMenu","setShowMobileMenu","handleRouteChange","events","on","off","shouldDisplayChildren","childModifiers","isMobileMenuExpanded","menuWrapperClasses","createElement","Provider","value","className","onClick","label","href","name","src","alt","propTypes","bool","isRequired","string","oneOfType","arrayOf","node","defaultProps"],"sources":["../../../src/components/Menu/Menu.js"],"sourcesContent":["import React, { useState, useEffect } from 'react';\nimport PropTypes from 'prop-types';\nimport BlazeButton from '@blaze-react/button';\nimport classnames from 'classnames';\nimport { useRouter } from 'next/router';\nimport { MdMenu, MdClose } from 'react-icons/md';\nimport { Link } from '@blaze-cms/nextjs-components';\nimport MenuContext from './MenuContext';\nimport BlazeLink from '../BlazeLink';\n\nconst Menu = ({\n children,\n collapse,\n modifier,\n mobileMenuModifier,\n mobileMenuChildrenModifier,\n mobileIconAlignment,\n mobileButtonModifier,\n hamburgerIconModifier,\n logoOnMobile,\n logoOnDesktop,\n logoOnMobileUrl,\n logoOnMobileAlt,\n logoOnMobileModifier,\n logoOnDesktopModifier,\n closeIconModifier\n}) => {\n const router = useRouter();\n const [showMobileMenu, setShowMobileMenu] = useState(false);\n\n useEffect(() => {\n const handleRouteChange = () => setShowMobileMenu(false);\n router.events.on('routeChangeStart', handleRouteChange);\n\n return () => {\n router.events.off('routeChangeStart', handleRouteChange);\n };\n }, [router.events]);\n\n const shouldDisplayChildren = collapse ? showMobileMenu : true;\n\n const childModifiers = classnames({\n [mobileMenuChildrenModifier]: shouldDisplayChildren,\n [modifier]: !showMobileMenu\n });\n\n const isMobileMenuExpanded = showMobileMenu ? `${mobileMenuModifier}` : '';\n const menuWrapperClasses = classnames('menu--wrapper', {\n 'menu--wrapper--mobile-open': showMobileMenu,\n 'menu--wrapper--mobile-closed': collapse && !showMobileMenu\n });\n\n return (\n <MenuContext.Provider value={{ showMobileMenu }}>\n <div className={menuWrapperClasses}>\n {collapse && (\n <div className=\"menu--mobile-wrapper\">\n <div\n className={`flex w-screen z-50 justify-${mobileIconAlignment} ${isMobileMenuExpanded}`}>\n <BlazeButton\n className={`menu--mobile-button ${mobileButtonModifier}`}\n onClick={() => setShowMobileMenu(!showMobileMenu)}\n label={showMobileMenu ? 'Close mobile menu' : 'Open mobile menu'}>\n <i>\n {showMobileMenu ? (\n <MdClose className={closeIconModifier} />\n ) : (\n <MdMenu className={hamburgerIconModifier} />\n )}\n </i>\n </BlazeButton>\n </div>\n </div>\n )}\n {logoOnMobile && !showMobileMenu && (\n <Link href=\"/\" name=\"mobile menu\">\n <img src={logoOnMobileUrl} alt={logoOnMobileAlt} className={logoOnMobileModifier} />\n </Link>\n )}\n\n <div className=\"menu--desktop-wrapper\">\n <ul className={childModifiers}>\n {logoOnDesktop && (\n <BlazeLink href=\"/\" className=\"\">\n <img\n src={logoOnMobileUrl}\n alt={logoOnMobileAlt}\n className={logoOnDesktopModifier}\n />\n </BlazeLink>\n )}\n {children}\n </ul>\n </div>\n </div>\n </MenuContext.Provider>\n );\n};\n\nMenu.propTypes = {\n collapse: PropTypes.bool.isRequired,\n logoOnMobile: PropTypes.bool.isRequired,\n logoOnDesktop: PropTypes.bool,\n logoOnMobileUrl: PropTypes.string,\n logoOnMobileAlt: PropTypes.string,\n logoOnMobileModifier: PropTypes.string,\n logoOnDesktopModifier: PropTypes.string,\n hamburgerIconModifier: PropTypes.string,\n closeIconModifier: PropTypes.string,\n mobileButtonModifier: PropTypes.string,\n mobileMenuModifier: PropTypes.string,\n mobileMenuChildrenModifier: PropTypes.string,\n modifier: PropTypes.string,\n mobileIconAlignment: PropTypes.string,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node])\n};\n\nMenu.defaultProps = {\n logoOnDesktop: false,\n logoOnMobileUrl: '',\n logoOnMobileAlt: '',\n logoOnMobileModifier: '',\n logoOnDesktopModifier: '',\n hamburgerIconModifier: '',\n closeIconModifier: '',\n mobileButtonModifier: '',\n mobileIconAlignment: '',\n mobileMenuModifier: '',\n mobileMenuChildrenModifier: '',\n modifier: '',\n children: []\n};\n\nexport default Menu;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuContext.js","names":["React","MenuContext","createContext","showMobileMenu"
|
|
1
|
+
{"version":3,"file":"MenuContext.js","names":["React","MenuContext","createContext","showMobileMenu"],"sources":["../../../src/components/Menu/MenuContext.js"],"sourcesContent":["import React from 'react';\n\nconst MenuContext = React.createContext({ showMobileMenu: false });\n\nexport default MenuContext;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAEzB,MAAMC,WAAW,GAAGD,KAAK,CAACE,aAAa,CAAC;EAAEC,cAAc,EAAE;AAAM,CAAC,CAAC;AAElE,eAAeF,WAAW","ignoreList":[]}
|
|
@@ -1,15 +1,13 @@
|
|
|
1
|
-
/* eslint-disable jsx-a11y/no-static-element-interactions */
|
|
2
1
|
import React, { useState, useContext, useEffect } from 'react';
|
|
3
2
|
import PropTypes from 'prop-types';
|
|
4
3
|
import { FaChevronDown, FaChevronUp } from 'react-icons/fa';
|
|
5
|
-
import classnames from 'classnames';
|
|
6
4
|
import { useRouter } from 'next/router';
|
|
7
5
|
import { useStringTemplate } from '@blaze-cms/utils-handlebars';
|
|
8
|
-
import { HOVER, MOUSE_ENTER, MOUSE_LEAVE, HIDDEN
|
|
6
|
+
import { HOVER, MOUSE_ENTER, MOUSE_LEAVE, HIDDEN } from '../../constants';
|
|
9
7
|
import { hasChildren } from '../../helpers';
|
|
10
8
|
import BlazeLink from '../BlazeLink';
|
|
11
9
|
import MenuContext from '../Menu/MenuContext';
|
|
12
|
-
import { injectHelperIntoTemplate
|
|
10
|
+
import { injectHelperIntoTemplate } from './helpers';
|
|
13
11
|
const MenuItemRender = ({
|
|
14
12
|
children,
|
|
15
13
|
eventType,
|
|
@@ -18,13 +16,10 @@ const MenuItemRender = ({
|
|
|
18
16
|
url,
|
|
19
17
|
parent
|
|
20
18
|
}) => {
|
|
21
|
-
const
|
|
19
|
+
const [displayChildren, setDisplayChildren] = useState(false);
|
|
22
20
|
const {
|
|
23
|
-
showMobileMenu
|
|
24
|
-
openActiveSubmenus
|
|
21
|
+
showMobileMenu
|
|
25
22
|
} = useContext(MenuContext);
|
|
26
|
-
const isHoverEvent = eventType === HOVER;
|
|
27
|
-
const isClickEvent = eventType === CLICK;
|
|
28
23
|
const {
|
|
29
24
|
loading: loadingText,
|
|
30
25
|
data: [textToUse]
|
|
@@ -33,21 +28,19 @@ const MenuItemRender = ({
|
|
|
33
28
|
loading: loadingUrl,
|
|
34
29
|
data: [urlToUse]
|
|
35
30
|
} = useStringTemplate(parent, [injectHelperIntoTemplate(url, 'url_encode')]);
|
|
36
|
-
const
|
|
37
|
-
const
|
|
38
|
-
const
|
|
31
|
+
const router = useRouter();
|
|
32
|
+
const isHoverEvent = eventType === HOVER;
|
|
33
|
+
const childrenDisplayClass = displayChildren ? '' : HIDDEN;
|
|
39
34
|
const hasValidChildren = hasChildren(children);
|
|
40
|
-
const [displayChildren, setDisplayChildren] = useState(shouldPreOpen);
|
|
41
35
|
useEffect(() => {
|
|
42
|
-
if (!showMobileMenu
|
|
43
|
-
}, [
|
|
36
|
+
if (!showMobileMenu) setDisplayChildren(false);
|
|
37
|
+
}, [showMobileMenu]);
|
|
44
38
|
useEffect(() => {
|
|
45
39
|
if (isHoverEvent) {
|
|
46
40
|
setDisplayChildren(false);
|
|
47
41
|
}
|
|
48
42
|
}, [router.asPath, isHoverEvent]);
|
|
49
43
|
if (loadingUrl || loadingText) return '';
|
|
50
|
-
const childrenDisplayClass = displayChildren ? '' : HIDDEN;
|
|
51
44
|
const handleItemEvent = ({
|
|
52
45
|
type
|
|
53
46
|
}) => {
|
|
@@ -65,25 +58,18 @@ const MenuItemRender = ({
|
|
|
65
58
|
setDisplayChildren(!displayChildren);
|
|
66
59
|
}
|
|
67
60
|
};
|
|
68
|
-
const menuItemLinkClassname = classnames('menu--item--link', {
|
|
69
|
-
'menu--item--link--active': isActive,
|
|
70
|
-
'menu--item--link--active-parent': isActiveParent
|
|
71
|
-
});
|
|
72
61
|
return /*#__PURE__*/React.createElement("li", {
|
|
73
62
|
className: modifier,
|
|
74
63
|
onMouseEnter: handleItemEvent,
|
|
75
64
|
onMouseLeave: handleItemEvent
|
|
76
65
|
}, /*#__PURE__*/React.createElement("div", {
|
|
77
|
-
className:
|
|
66
|
+
className: "menu--item--link",
|
|
78
67
|
onClick: handleMobileClick,
|
|
79
68
|
role: !urlToUse && hasValidChildren ? 'button' : undefined,
|
|
80
69
|
tabIndex: !urlToUse && hasValidChildren ? 0 : undefined
|
|
81
70
|
}, urlToUse ? /*#__PURE__*/React.createElement(BlazeLink, {
|
|
82
71
|
href: urlToUse
|
|
83
|
-
}, textToUse) : /*#__PURE__*/React.createElement("span", {
|
|
84
|
-
role: "button",
|
|
85
|
-
onClick: handleItemEvent
|
|
86
|
-
}, textToUse), hasValidChildren && /*#__PURE__*/React.createElement("i", {
|
|
72
|
+
}, textToUse) : /*#__PURE__*/React.createElement("span", null, textToUse), hasValidChildren && /*#__PURE__*/React.createElement("i", {
|
|
87
73
|
role: "button",
|
|
88
74
|
className: "menu--item--link--icon",
|
|
89
75
|
onClick: e => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuItemRender.js","names":["React","useState","useContext","useEffect","PropTypes","FaChevronDown","FaChevronUp","
|
|
1
|
+
{"version":3,"file":"MenuItemRender.js","names":["React","useState","useContext","useEffect","PropTypes","FaChevronDown","FaChevronUp","useRouter","useStringTemplate","HOVER","MOUSE_ENTER","MOUSE_LEAVE","HIDDEN","hasChildren","BlazeLink","MenuContext","injectHelperIntoTemplate","MenuItemRender","children","eventType","text","modifier","url","parent","displayChildren","setDisplayChildren","showMobileMenu","loading","loadingText","data","textToUse","loadingUrl","urlToUse","router","isHoverEvent","childrenDisplayClass","hasValidChildren","asPath","handleItemEvent","type","handleMobileClick","createElement","className","onMouseEnter","onMouseLeave","onClick","role","undefined","tabIndex","href","e","stopPropagation","propTypes","string","isRequired","object","oneOfType","arrayOf","node","defaultProps"],"sources":["../../../src/components/MenuItem/MenuItemRender.js"],"sourcesContent":["import React, { useState, useContext, useEffect } from 'react';\nimport PropTypes from 'prop-types';\nimport { FaChevronDown, FaChevronUp } from 'react-icons/fa';\nimport { useRouter } from 'next/router';\nimport { useStringTemplate } from '@blaze-cms/utils-handlebars';\nimport { HOVER, MOUSE_ENTER, MOUSE_LEAVE, HIDDEN } from '../../constants';\nimport { hasChildren } from '../../helpers';\nimport BlazeLink from '../BlazeLink';\nimport MenuContext from '../Menu/MenuContext';\nimport { injectHelperIntoTemplate } from './helpers';\n\nconst MenuItemRender = ({ children, eventType, text, modifier, url, parent }) => {\n const [displayChildren, setDisplayChildren] = useState(false);\n const { showMobileMenu } = useContext(MenuContext);\n const {\n loading: loadingText,\n data: [textToUse]\n } = useStringTemplate(parent, [text]);\n const {\n loading: loadingUrl,\n data: [urlToUse]\n } = useStringTemplate(parent, [injectHelperIntoTemplate(url, 'url_encode')]);\n\n const router = useRouter();\n const isHoverEvent = eventType === HOVER;\n const childrenDisplayClass = displayChildren ? '' : HIDDEN;\n const hasValidChildren = hasChildren(children);\n\n useEffect(() => {\n if (!showMobileMenu) setDisplayChildren(false);\n }, [showMobileMenu]);\n\n useEffect(() => {\n if (isHoverEvent) {\n setDisplayChildren(false);\n }\n }, [router.asPath, isHoverEvent]);\n\n if (loadingUrl || loadingText) return '';\n\n const handleItemEvent = ({ type }) => {\n if (isHoverEvent) {\n if (type === MOUSE_ENTER) {\n setDisplayChildren(true);\n }\n if (type === MOUSE_LEAVE) {\n setDisplayChildren(false);\n }\n }\n };\n\n const handleMobileClick = () => {\n if (!urlToUse && hasValidChildren) {\n setDisplayChildren(!displayChildren);\n }\n };\n\n return (\n <li className={modifier} onMouseEnter={handleItemEvent} onMouseLeave={handleItemEvent}>\n <div\n className=\"menu--item--link\"\n onClick={handleMobileClick}\n role={!urlToUse && hasValidChildren ? 'button' : undefined}\n tabIndex={!urlToUse && hasValidChildren ? 0 : undefined}>\n {urlToUse ? <BlazeLink href={urlToUse}>{textToUse}</BlazeLink> : <span>{textToUse}</span>}\n\n {hasValidChildren && (\n <i\n role=\"button\"\n className=\"menu--item--link--icon\"\n onClick={e => {\n e.stopPropagation();\n setDisplayChildren(!displayChildren);\n }}\n tabIndex={0}>\n {displayChildren ? <FaChevronUp /> : <FaChevronDown />}\n </i>\n )}\n </div>\n\n {hasValidChildren && (\n <div className={`menu--item-children ${childrenDisplayClass}`}>{children}</div>\n )}\n </li>\n );\n};\n\nMenuItemRender.propTypes = {\n modifier: PropTypes.string,\n text: PropTypes.string,\n url: PropTypes.string,\n eventType: PropTypes.string.isRequired,\n parent: PropTypes.object,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node])\n};\n\nMenuItemRender.defaultProps = {\n url: '',\n modifier: '',\n text: '',\n children: null,\n parent: {}\n};\n\nexport default MenuItemRender;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,5 +1,3 @@
|
|
|
1
1
|
import injectHelperIntoTemplate from './inject-helper-into-template';
|
|
2
|
-
|
|
3
|
-
import hasActiveChild from './has-active-child';
|
|
4
|
-
export { injectHelperIntoTemplate, isUrlPathMatch, hasActiveChild };
|
|
2
|
+
export { injectHelperIntoTemplate };
|
|
5
3
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["injectHelperIntoTemplate"
|
|
1
|
+
{"version":3,"file":"index.js","names":["injectHelperIntoTemplate"],"sources":["../../../../src/components/MenuItem/helpers/index.js"],"sourcesContent":["import injectHelperIntoTemplate from './inject-helper-into-template';\n\nexport { injectHelperIntoTemplate };\n"],"mappings":"AAAA,OAAOA,wBAAwB,MAAM,+BAA+B;AAEpE,SAASA,wBAAwB","ignoreList":[]}
|
|
@@ -4,7 +4,7 @@ import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProper
|
|
|
4
4
|
const _excluded = ["childNode"];
|
|
5
5
|
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; }
|
|
6
6
|
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; }
|
|
7
|
-
import { useState, useEffect } from 'react';
|
|
7
|
+
import React, { useState, useEffect } from 'react';
|
|
8
8
|
import { EDITOR_MODE_ICON_CLASS, EDITOR_MODE_HIGHLIGHT_CLASS } from './constants';
|
|
9
9
|
const BlazeLogo = _ref => {
|
|
10
10
|
let {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BlazeLogo.js","names":["useState","useEffect","EDITOR_MODE_ICON_CLASS","EDITOR_MODE_HIGHLIGHT_CLASS","BlazeLogo","_ref","childNode","props","_objectWithoutProperties","_excluded","id","style","setStyle","rect","getBoundingClientRect","left","width","window","scrollX","top","scrollY","display","classList","contains","newStyle","observer","MutationObserver","mutations","forEach","mutation","type","attributeName","isHighlighted","_objectSpread","observe","attributes","disconnect","
|
|
1
|
+
{"version":3,"file":"BlazeLogo.js","names":["React","useState","useEffect","EDITOR_MODE_ICON_CLASS","EDITOR_MODE_HIGHLIGHT_CLASS","BlazeLogo","_ref","childNode","props","_objectWithoutProperties","_excluded","id","style","setStyle","rect","getBoundingClientRect","left","width","window","scrollX","top","scrollY","display","classList","contains","newStyle","observer","MutationObserver","mutations","forEach","mutation","type","attributeName","isHighlighted","_objectSpread","observe","attributes","disconnect","createElement","_extends","className","xmlns","height","fill","transform","d","fillRule"],"sources":["../../../src/system-components/EditorMode/BlazeLogo.js"],"sourcesContent":["import React, { useState, useEffect } from 'react';\nimport { EDITOR_MODE_ICON_CLASS, EDITOR_MODE_HIGHLIGHT_CLASS } from './constants';\n\nconst BlazeLogo = ({ childNode, ...props }) => {\n const { id } = props;\n const [style, setStyle] = useState({});\n\n useEffect(() => {\n if (!childNode) return;\n\n const rect = childNode.getBoundingClientRect();\n const left = rect.width / 2 + rect.left + window.scrollX;\n const top = rect.top - 20 + window.scrollY;\n const display = childNode.classList.contains(EDITOR_MODE_HIGHLIGHT_CLASS) ? null : 'none';\n const newStyle = { display, top, left };\n setStyle(newStyle);\n\n const observer = new MutationObserver(mutations => {\n mutations.forEach(mutation => {\n if (mutation.type === 'attributes' && mutation.attributeName === 'class') {\n const isHighlighted = childNode.classList.contains(EDITOR_MODE_HIGHLIGHT_CLASS);\n setStyle({ ...newStyle, display: isHighlighted ? null : 'none' });\n }\n });\n });\n observer.observe(childNode, { attributes: true });\n return () => observer.disconnect();\n }, [childNode, id]);\n\n // todo: fix icon hover/click activation while using position absolute\n return (\n <button type=\"button\" className={EDITOR_MODE_ICON_CLASS} {...props} style={style}>\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"22\" height=\"33\">\n <path\n fill=\"currentColor\"\n transform=\"translate(1.0415 1.85962)\"\n d=\"M7.0214715 6.2017469C7.0214715 6.2017469 4.6948299 13.380771 5.2965479 15.065234C5.6174636 15.947572 6.3796396 16.18821 7.3022733 15.386085C9.1074257 13.781834 13.078762 6.3621721 9.949831 0.42644304C8.7463951 -1.8596147 18.293648 5.1589837 16.328037 18.755013C16.087351 20.559793 16.809412 19.998306 17.250671 19.236286C19.176168 15.947572 17.972733 11.616095 17.972733 10.894181C17.972733 10.172268 19.657541 12.939602 19.777885 18.353949C19.89823 23.768295 17.050098 29.022219 11.393953 29.98477C10.03006 30.225407 13.199106 27.578392 13.640366 24.610529C13.68048 24.329784 10.39109 28.300306 9.5888004 27.738817C9.2277699 27.49818 15.36529 19.877987 13.199106 13.300558C13.158992 13.140133 11.754984 24.409996 6.3796396 27.097116C3.3309369 28.621155 0.60315031 25.051697 0.12177619 21.963514C-1.0415446 13.862046 6.4999828 8.7284422 7.0214715 6.2017469Z\"\n fillRule=\"evenodd\"\n />\n </svg>\n </button>\n );\n};\n\nexport default BlazeLogo;\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,QAAQ,EAAEC,SAAS,QAAQ,OAAO;AAClD,SAASC,sBAAsB,EAAEC,2BAA2B,QAAQ,aAAa;AAEjF,MAAMC,SAAS,GAAGC,IAAA,IAA6B;EAAA,IAA5B;MAAEC;IAAoB,CAAC,GAAAD,IAAA;IAAPE,KAAK,GAAAC,wBAAA,CAAAH,IAAA,EAAAI,SAAA;EACtC,MAAM;IAAEC;EAAG,CAAC,GAAGH,KAAK;EACpB,MAAM,CAACI,KAAK,EAAEC,QAAQ,CAAC,GAAGZ,QAAQ,CAAC,CAAC,CAAC,CAAC;EAEtCC,SAAS,CAAC,MAAM;IACd,IAAI,CAACK,SAAS,EAAE;IAEhB,MAAMO,IAAI,GAAGP,SAAS,CAACQ,qBAAqB,CAAC,CAAC;IAC9C,MAAMC,IAAI,GAAGF,IAAI,CAACG,KAAK,GAAG,CAAC,GAAGH,IAAI,CAACE,IAAI,GAAGE,MAAM,CAACC,OAAO;IACxD,MAAMC,GAAG,GAAGN,IAAI,CAACM,GAAG,GAAG,EAAE,GAAGF,MAAM,CAACG,OAAO;IAC1C,MAAMC,OAAO,GAAGf,SAAS,CAACgB,SAAS,CAACC,QAAQ,CAACpB,2BAA2B,CAAC,GAAG,IAAI,GAAG,MAAM;IACzF,MAAMqB,QAAQ,GAAG;MAAEH,OAAO;MAAEF,GAAG;MAAEJ;IAAK,CAAC;IACvCH,QAAQ,CAACY,QAAQ,CAAC;IAElB,MAAMC,QAAQ,GAAG,IAAIC,gBAAgB,CAACC,SAAS,IAAI;MACjDA,SAAS,CAACC,OAAO,CAACC,QAAQ,IAAI;QAC5B,IAAIA,QAAQ,CAACC,IAAI,KAAK,YAAY,IAAID,QAAQ,CAACE,aAAa,KAAK,OAAO,EAAE;UACxE,MAAMC,aAAa,GAAG1B,SAAS,CAACgB,SAAS,CAACC,QAAQ,CAACpB,2BAA2B,CAAC;UAC/ES,QAAQ,CAAAqB,aAAA,CAAAA,aAAA,KAAMT,QAAQ;YAAEH,OAAO,EAAEW,aAAa,GAAG,IAAI,GAAG;UAAM,EAAE,CAAC;QACnE;MACF,CAAC,CAAC;IACJ,CAAC,CAAC;IACFP,QAAQ,CAACS,OAAO,CAAC5B,SAAS,EAAE;MAAE6B,UAAU,EAAE;IAAK,CAAC,CAAC;IACjD,OAAO,MAAMV,QAAQ,CAACW,UAAU,CAAC,CAAC;EACpC,CAAC,EAAE,CAAC9B,SAAS,EAAEI,EAAE,CAAC,CAAC;;EAEnB;EACA,oBACEX,KAAA,CAAAsC,aAAA,WAAAC,QAAA;IAAQR,IAAI,EAAC,QAAQ;IAACS,SAAS,EAAErC;EAAuB,GAAKK,KAAK;IAAEI,KAAK,EAAEA;EAAM,iBAC/EZ,KAAA,CAAAsC,aAAA;IAAKG,KAAK,EAAC,4BAA4B;IAACxB,KAAK,EAAC,IAAI;IAACyB,MAAM,EAAC;EAAI,gBAC5D1C,KAAA,CAAAsC,aAAA;IACEK,IAAI,EAAC,cAAc;IACnBC,SAAS,EAAC,2BAA2B;IACrCC,CAAC,EAAC,21BAA21B;IAC71BC,QAAQ,EAAC;EAAS,CACnB,CACE,CACC,CAAC;AAEb,CAAC;AAED,eAAezC,SAAS","ignoreList":[]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { useRef, useEffect, useState } from 'react';
|
|
1
|
+
import React, { useRef, useEffect, useState } from 'react';
|
|
2
2
|
import { createPortal } from 'react-dom';
|
|
3
3
|
import { useMainContext } from '@blaze-cms/nextjs-components';
|
|
4
4
|
import addEditorModeEventListeners from './helpers/add-editor-mode-event-listeners';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PbWrapper.js","names":["useRef","useEffect","useState","createPortal","useMainContext","addEditorModeEventListeners","BlazeLogo","PbWrapper","name","type","ref","logoProps","setLogoProps","debugOptions","adminHref","unmount","TagName","
|
|
1
|
+
{"version":3,"file":"PbWrapper.js","names":["React","useRef","useEffect","useState","createPortal","useMainContext","addEditorModeEventListeners","BlazeLogo","PbWrapper","name","type","ref","logoProps","setLogoProps","debugOptions","adminHref","unmount","TagName","createElement","Fragment","document","body"],"sources":["../../../src/system-components/EditorMode/PbWrapper.js"],"sourcesContent":["import React, { useRef, useEffect, useState } from 'react';\nimport { createPortal } from 'react-dom';\nimport { useMainContext } from '@blaze-cms/nextjs-components';\nimport addEditorModeEventListeners from './helpers/add-editor-mode-event-listeners';\nimport BlazeLogo from './BlazeLogo';\n\nconst PbWrapper = ({ name, type = 'start' }) => {\n const ref = useRef(null);\n const [logoProps, setLogoProps] = useState(null);\n const { debugOptions: { adminHref } = {} } = useMainContext();\n\n useEffect(() => {\n const unmount = addEditorModeEventListeners({ ref, name, adminHref, type, setLogoProps });\n\n return unmount;\n }, [adminHref, name, type]);\n\n const TagName = `pb-wrapper-${type}`;\n return (\n <>\n <TagName ref={ref} pb-component-name={name} />\n {logoProps && createPortal(<BlazeLogo {...logoProps} />, document.body)}\n </>\n );\n};\n\nexport default PbWrapper;\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,MAAM,EAAEC,SAAS,EAAEC,QAAQ,QAAQ,OAAO;AAC1D,SAASC,YAAY,QAAQ,WAAW;AACxC,SAASC,cAAc,QAAQ,8BAA8B;AAC7D,OAAOC,2BAA2B,MAAM,2CAA2C;AACnF,OAAOC,SAAS,MAAM,aAAa;AAEnC,MAAMC,SAAS,GAAGA,CAAC;EAAEC,IAAI;EAAEC,IAAI,GAAG;AAAQ,CAAC,KAAK;EAC9C,MAAMC,GAAG,GAAGV,MAAM,CAAC,IAAI,CAAC;EACxB,MAAM,CAACW,SAAS,EAAEC,YAAY,CAAC,GAAGV,QAAQ,CAAC,IAAI,CAAC;EAChD,MAAM;IAAEW,YAAY,EAAE;MAAEC;IAAU,CAAC,GAAG,CAAC;EAAE,CAAC,GAAGV,cAAc,CAAC,CAAC;EAE7DH,SAAS,CAAC,MAAM;IACd,MAAMc,OAAO,GAAGV,2BAA2B,CAAC;MAAEK,GAAG;MAAEF,IAAI;MAAEM,SAAS;MAAEL,IAAI;MAAEG;IAAa,CAAC,CAAC;IAEzF,OAAOG,OAAO;EAChB,CAAC,EAAE,CAACD,SAAS,EAAEN,IAAI,EAAEC,IAAI,CAAC,CAAC;EAE3B,MAAMO,OAAO,GAAG,cAAcP,IAAI,EAAE;EACpC,oBACEV,KAAA,CAAAkB,aAAA,CAAAlB,KAAA,CAAAmB,QAAA,qBACEnB,KAAA,CAAAkB,aAAA,CAACD,OAAO;IAACN,GAAG,EAAEA,GAAI;IAAC,qBAAmBF;EAAK,CAAE,CAAC,EAC7CG,SAAS,IAAIR,YAAY,cAACJ,KAAA,CAAAkB,aAAA,CAACX,SAAS,EAAKK,SAAY,CAAC,EAAEQ,QAAQ,CAACC,IAAI,CACtE,CAAC;AAEP,CAAC;AAED,eAAeb,SAAS","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@blaze-cms/react-page-builder",
|
|
3
|
-
"version": "0.146.0-node18-
|
|
3
|
+
"version": "0.146.0-node18-tooltips.0",
|
|
4
4
|
"description": "Blaze react page builder",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"module": "lib-es/index.js",
|
|
@@ -27,15 +27,15 @@
|
|
|
27
27
|
},
|
|
28
28
|
"license": "GPL-3.0",
|
|
29
29
|
"dependencies": {
|
|
30
|
-
"@blaze-cms/core-auth-ui": "0.146.0-node18-
|
|
31
|
-
"@blaze-cms/core-errors": "0.146.0-node18-
|
|
32
|
-
"@blaze-cms/core-errors-ui": "0.146.0-node18-
|
|
30
|
+
"@blaze-cms/core-auth-ui": "0.146.0-node18-tooltips.0",
|
|
31
|
+
"@blaze-cms/core-errors": "0.146.0-node18-tooltips.0",
|
|
32
|
+
"@blaze-cms/core-errors-ui": "0.146.0-node18-tooltips.0",
|
|
33
33
|
"@blaze-cms/image-cdn-react": "0.3.0-alpha.7",
|
|
34
|
-
"@blaze-cms/nextjs-components": "0.146.0-node18-
|
|
35
|
-
"@blaze-cms/plugin-search-ui": "0.146.0-node18-
|
|
36
|
-
"@blaze-cms/setup-ui": "0.146.0-node18-
|
|
37
|
-
"@blaze-cms/utils": "0.146.0-node18-
|
|
38
|
-
"@blaze-cms/utils-handlebars": "0.146.0-node18-
|
|
34
|
+
"@blaze-cms/nextjs-components": "0.146.0-node18-tooltips.0",
|
|
35
|
+
"@blaze-cms/plugin-search-ui": "0.146.0-node18-tooltips.0",
|
|
36
|
+
"@blaze-cms/setup-ui": "0.146.0-node18-tooltips.0",
|
|
37
|
+
"@blaze-cms/utils": "0.146.0-node18-tooltips.0",
|
|
38
|
+
"@blaze-cms/utils-handlebars": "0.146.0-node18-tooltips.0",
|
|
39
39
|
"@blaze-react/badge": "^0.7.0",
|
|
40
40
|
"@blaze-react/breadcrumb": "0.8.0-alpha.60",
|
|
41
41
|
"@blaze-react/button": "0.8.0-alpha.82",
|
|
@@ -92,5 +92,5 @@
|
|
|
92
92
|
"lib/*",
|
|
93
93
|
"lib-es/*"
|
|
94
94
|
],
|
|
95
|
-
"gitHead": "
|
|
95
|
+
"gitHead": "d54711bafcf5b7a943ed347d9ef50f7985f93c58"
|
|
96
96
|
}
|
|
@@ -11,7 +11,6 @@ import BlazeLink from '../BlazeLink';
|
|
|
11
11
|
const Menu = ({
|
|
12
12
|
children,
|
|
13
13
|
collapse,
|
|
14
|
-
openActiveSubmenus,
|
|
15
14
|
modifier,
|
|
16
15
|
mobileMenuModifier,
|
|
17
16
|
mobileMenuChildrenModifier,
|
|
@@ -52,7 +51,7 @@ const Menu = ({
|
|
|
52
51
|
});
|
|
53
52
|
|
|
54
53
|
return (
|
|
55
|
-
<MenuContext.Provider value={{ showMobileMenu
|
|
54
|
+
<MenuContext.Provider value={{ showMobileMenu }}>
|
|
56
55
|
<div className={menuWrapperClasses}>
|
|
57
56
|
{collapse && (
|
|
58
57
|
<div className="menu--mobile-wrapper">
|
|
@@ -100,7 +99,6 @@ const Menu = ({
|
|
|
100
99
|
|
|
101
100
|
Menu.propTypes = {
|
|
102
101
|
collapse: PropTypes.bool.isRequired,
|
|
103
|
-
openActiveSubmenus: PropTypes.bool.isRequired,
|
|
104
102
|
logoOnMobile: PropTypes.bool.isRequired,
|
|
105
103
|
logoOnDesktop: PropTypes.bool,
|
|
106
104
|
logoOnMobileUrl: PropTypes.string,
|
|
@@ -1,23 +1,17 @@
|
|
|
1
|
-
/* eslint-disable jsx-a11y/no-static-element-interactions */
|
|
2
1
|
import React, { useState, useContext, useEffect } from 'react';
|
|
3
2
|
import PropTypes from 'prop-types';
|
|
4
3
|
import { FaChevronDown, FaChevronUp } from 'react-icons/fa';
|
|
5
|
-
import classnames from 'classnames';
|
|
6
4
|
import { useRouter } from 'next/router';
|
|
7
5
|
import { useStringTemplate } from '@blaze-cms/utils-handlebars';
|
|
8
|
-
import { HOVER, MOUSE_ENTER, MOUSE_LEAVE, HIDDEN
|
|
6
|
+
import { HOVER, MOUSE_ENTER, MOUSE_LEAVE, HIDDEN } from '../../constants';
|
|
9
7
|
import { hasChildren } from '../../helpers';
|
|
10
8
|
import BlazeLink from '../BlazeLink';
|
|
11
9
|
import MenuContext from '../Menu/MenuContext';
|
|
12
|
-
import { injectHelperIntoTemplate
|
|
10
|
+
import { injectHelperIntoTemplate } from './helpers';
|
|
13
11
|
|
|
14
12
|
const MenuItemRender = ({ children, eventType, text, modifier, url, parent }) => {
|
|
15
|
-
const
|
|
16
|
-
const { showMobileMenu
|
|
17
|
-
|
|
18
|
-
const isHoverEvent = eventType === HOVER;
|
|
19
|
-
const isClickEvent = eventType === CLICK;
|
|
20
|
-
|
|
13
|
+
const [displayChildren, setDisplayChildren] = useState(false);
|
|
14
|
+
const { showMobileMenu } = useContext(MenuContext);
|
|
21
15
|
const {
|
|
22
16
|
loading: loadingText,
|
|
23
17
|
data: [textToUse]
|
|
@@ -27,24 +21,14 @@ const MenuItemRender = ({ children, eventType, text, modifier, url, parent }) =>
|
|
|
27
21
|
data: [urlToUse]
|
|
28
22
|
} = useStringTemplate(parent, [injectHelperIntoTemplate(url, 'url_encode')]);
|
|
29
23
|
|
|
30
|
-
const
|
|
31
|
-
const
|
|
32
|
-
const
|
|
24
|
+
const router = useRouter();
|
|
25
|
+
const isHoverEvent = eventType === HOVER;
|
|
26
|
+
const childrenDisplayClass = displayChildren ? '' : HIDDEN;
|
|
33
27
|
const hasValidChildren = hasChildren(children);
|
|
34
28
|
|
|
35
|
-
const [displayChildren, setDisplayChildren] = useState(shouldPreOpen);
|
|
36
|
-
|
|
37
29
|
useEffect(() => {
|
|
38
|
-
if (!showMobileMenu
|
|
39
|
-
}, [
|
|
40
|
-
children,
|
|
41
|
-
isClickEvent,
|
|
42
|
-
loadingUrl,
|
|
43
|
-
openActiveSubmenus,
|
|
44
|
-
router,
|
|
45
|
-
shouldPreOpen,
|
|
46
|
-
showMobileMenu
|
|
47
|
-
]);
|
|
30
|
+
if (!showMobileMenu) setDisplayChildren(false);
|
|
31
|
+
}, [showMobileMenu]);
|
|
48
32
|
|
|
49
33
|
useEffect(() => {
|
|
50
34
|
if (isHoverEvent) {
|
|
@@ -54,8 +38,6 @@ const MenuItemRender = ({ children, eventType, text, modifier, url, parent }) =>
|
|
|
54
38
|
|
|
55
39
|
if (loadingUrl || loadingText) return '';
|
|
56
40
|
|
|
57
|
-
const childrenDisplayClass = displayChildren ? '' : HIDDEN;
|
|
58
|
-
|
|
59
41
|
const handleItemEvent = ({ type }) => {
|
|
60
42
|
if (isHoverEvent) {
|
|
61
43
|
if (type === MOUSE_ENTER) {
|
|
@@ -73,25 +55,15 @@ const MenuItemRender = ({ children, eventType, text, modifier, url, parent }) =>
|
|
|
73
55
|
}
|
|
74
56
|
};
|
|
75
57
|
|
|
76
|
-
const menuItemLinkClassname = classnames('menu--item--link', {
|
|
77
|
-
'menu--item--link--active': isActive,
|
|
78
|
-
'menu--item--link--active-parent': isActiveParent
|
|
79
|
-
});
|
|
80
|
-
|
|
81
58
|
return (
|
|
82
59
|
<li className={modifier} onMouseEnter={handleItemEvent} onMouseLeave={handleItemEvent}>
|
|
83
60
|
<div
|
|
84
|
-
className=
|
|
61
|
+
className="menu--item--link"
|
|
85
62
|
onClick={handleMobileClick}
|
|
86
63
|
role={!urlToUse && hasValidChildren ? 'button' : undefined}
|
|
87
64
|
tabIndex={!urlToUse && hasValidChildren ? 0 : undefined}>
|
|
88
|
-
{urlToUse ?
|
|
89
|
-
|
|
90
|
-
) : (
|
|
91
|
-
<span role="button" onClick={handleItemEvent}>
|
|
92
|
-
{textToUse}
|
|
93
|
-
</span>
|
|
94
|
-
)}
|
|
65
|
+
{urlToUse ? <BlazeLink href={urlToUse}>{textToUse}</BlazeLink> : <span>{textToUse}</span>}
|
|
66
|
+
|
|
95
67
|
{hasValidChildren && (
|
|
96
68
|
<i
|
|
97
69
|
role="button"
|
|
@@ -1,5 +1,3 @@
|
|
|
1
1
|
import injectHelperIntoTemplate from './inject-helper-into-template';
|
|
2
|
-
import isUrlPathMatch from './isUrlPathMatch';
|
|
3
|
-
import hasActiveChild from './has-active-child';
|
|
4
2
|
|
|
5
|
-
export { injectHelperIntoTemplate
|
|
3
|
+
export { injectHelperIntoTemplate };
|
|
@@ -1,34 +1,31 @@
|
|
|
1
|
-
import { useState, useEffect } from 'react';
|
|
1
|
+
import React, { useState, useEffect } from 'react';
|
|
2
2
|
import { EDITOR_MODE_ICON_CLASS, EDITOR_MODE_HIGHLIGHT_CLASS } from './constants';
|
|
3
3
|
|
|
4
4
|
const BlazeLogo = ({ childNode, ...props }) => {
|
|
5
5
|
const { id } = props;
|
|
6
6
|
const [style, setStyle] = useState({});
|
|
7
7
|
|
|
8
|
-
useEffect(
|
|
9
|
-
()
|
|
10
|
-
if (!childNode) return;
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
if (!childNode) return;
|
|
11
10
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
11
|
+
const rect = childNode.getBoundingClientRect();
|
|
12
|
+
const left = rect.width / 2 + rect.left + window.scrollX;
|
|
13
|
+
const top = rect.top - 20 + window.scrollY;
|
|
14
|
+
const display = childNode.classList.contains(EDITOR_MODE_HIGHLIGHT_CLASS) ? null : 'none';
|
|
15
|
+
const newStyle = { display, top, left };
|
|
16
|
+
setStyle(newStyle);
|
|
18
17
|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
});
|
|
18
|
+
const observer = new MutationObserver(mutations => {
|
|
19
|
+
mutations.forEach(mutation => {
|
|
20
|
+
if (mutation.type === 'attributes' && mutation.attributeName === 'class') {
|
|
21
|
+
const isHighlighted = childNode.classList.contains(EDITOR_MODE_HIGHLIGHT_CLASS);
|
|
22
|
+
setStyle({ ...newStyle, display: isHighlighted ? null : 'none' });
|
|
23
|
+
}
|
|
26
24
|
});
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
);
|
|
25
|
+
});
|
|
26
|
+
observer.observe(childNode, { attributes: true });
|
|
27
|
+
return () => observer.disconnect();
|
|
28
|
+
}, [childNode, id]);
|
|
32
29
|
|
|
33
30
|
// todo: fix icon hover/click activation while using position absolute
|
|
34
31
|
return (
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { useRef, useEffect, useState } from 'react';
|
|
1
|
+
import React, { useRef, useEffect, useState } from 'react';
|
|
2
2
|
import { createPortal } from 'react-dom';
|
|
3
3
|
import { useMainContext } from '@blaze-cms/nextjs-components';
|
|
4
4
|
import addEditorModeEventListeners from './helpers/add-editor-mode-event-listeners';
|
|
@@ -9,14 +9,11 @@ const PbWrapper = ({ name, type = 'start' }) => {
|
|
|
9
9
|
const [logoProps, setLogoProps] = useState(null);
|
|
10
10
|
const { debugOptions: { adminHref } = {} } = useMainContext();
|
|
11
11
|
|
|
12
|
-
useEffect(
|
|
13
|
-
(
|
|
14
|
-
const unmount = addEditorModeEventListeners({ ref, name, adminHref, type, setLogoProps });
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
const unmount = addEditorModeEventListeners({ ref, name, adminHref, type, setLogoProps });
|
|
15
14
|
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
[adminHref, name, type]
|
|
19
|
-
);
|
|
15
|
+
return unmount;
|
|
16
|
+
}, [adminHref, name, type]);
|
|
20
17
|
|
|
21
18
|
const TagName = `pb-wrapper-${type}`;
|
|
22
19
|
return (
|
|
@@ -19,11 +19,6 @@ jest.mock('next/router', () => ({
|
|
|
19
19
|
useRouter: () => ({ asPath: '/' })
|
|
20
20
|
}));
|
|
21
21
|
|
|
22
|
-
// todo: add extra tests to support this util
|
|
23
|
-
jest.mock('../../../../../src/components/MenuItem/helpers/has-active-child', () =>
|
|
24
|
-
jest.fn(() => false)
|
|
25
|
-
);
|
|
26
|
-
|
|
27
22
|
const componentProps = {
|
|
28
23
|
id: 'id',
|
|
29
24
|
name: 'mock name',
|
|
@@ -11,22 +11,14 @@ const MENU_ITEM_CHILDREN_CLASS = 'menu--item-children';
|
|
|
11
11
|
|
|
12
12
|
let mockAsPathValue = '/';
|
|
13
13
|
|
|
14
|
-
jest.mock('next/router', () => {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
useRouter: () => router
|
|
18
|
-
};
|
|
19
|
-
});
|
|
14
|
+
jest.mock('next/router', () => ({
|
|
15
|
+
useRouter: () => ({ asPath: mockAsPathValue })
|
|
16
|
+
}));
|
|
20
17
|
|
|
21
18
|
jest.mock('@blaze-cms/utils-handlebars', () => ({
|
|
22
19
|
useStringTemplate: jest.fn((parent, [title]) => ({ loading: false, data: [title] }))
|
|
23
20
|
}));
|
|
24
21
|
|
|
25
|
-
// todo: add extra tests to support this util
|
|
26
|
-
jest.mock('../../../../../src/components/MenuItem/helpers/has-active-child', () =>
|
|
27
|
-
jest.fn(() => false)
|
|
28
|
-
);
|
|
29
|
-
|
|
30
22
|
describe('MenuRender component', () => {
|
|
31
23
|
it('renders menu item with link when URL is provided', () => {
|
|
32
24
|
const { getByText } = render(<MenuRender eventType="click" text="Home" url="/home" />);
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
require("core-js/modules/es.object.define-property.js");
|
|
4
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
5
|
-
Object.defineProperty(exports, "__esModule", {
|
|
6
|
-
value: true
|
|
7
|
-
});
|
|
8
|
-
exports["default"] = void 0;
|
|
9
|
-
require("core-js/modules/es.array.find.js");
|
|
10
|
-
require("core-js/modules/es.object.to-string.js");
|
|
11
|
-
var _isUrlPathMatch = _interopRequireDefault(require("./isUrlPathMatch"));
|
|
12
|
-
var _helpers = require("../../../helpers");
|
|
13
|
-
var hasActiveChild = function hasActiveChild(path, children) {
|
|
14
|
-
return (0, _helpers.hasChildren)(children) && children.props.children[1][0].props.component.items.find(function (menuItem) {
|
|
15
|
-
return (0, _isUrlPathMatch["default"])(path, menuItem.settings.url);
|
|
16
|
-
});
|
|
17
|
-
};
|
|
18
|
-
var _default = exports["default"] = hasActiveChild;
|
|
19
|
-
//# sourceMappingURL=has-active-child.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"has-active-child.js","names":["_isUrlPathMatch","_interopRequireDefault","require","_helpers","hasActiveChild","path","children","hasChildren","props","component","items","find","menuItem","isUrlPathMatch","settings","url","_default","exports"],"sources":["../../../../src/components/MenuItem/helpers/has-active-child.js"],"sourcesContent":["import isUrlPathMatch from './isUrlPathMatch';\nimport { hasChildren } from '../../../helpers';\n\nconst hasActiveChild = (path, children) =>\n hasChildren(children) &&\n children.props.children[1][0].props.component.items.find(menuItem =>\n isUrlPathMatch(path, menuItem.settings.url)\n );\n\nexport default hasActiveChild;\n"],"mappings":";;;;;;;;;;AAAA,IAAAA,eAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AAEA,IAAME,cAAc,GAAG,SAAjBA,cAAcA,CAAIC,IAAI,EAAEC,QAAQ;EAAA,OACpC,IAAAC,oBAAW,EAACD,QAAQ,CAAC,IACrBA,QAAQ,CAACE,KAAK,CAACF,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAACE,KAAK,CAACC,SAAS,CAACC,KAAK,CAACC,IAAI,CAAC,UAAAC,QAAQ;IAAA,OAC/D,IAAAC,0BAAc,EAACR,IAAI,EAAEO,QAAQ,CAACE,QAAQ,CAACC,GAAG,CAAC;EAAA,CAC7C,CAAC;AAAA;AAAC,IAAAC,QAAA,GAAAC,OAAA,cAEWb,cAAc","ignoreList":[]}
|