payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
138 lines (137 loc) • 14.7 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "ToolbarControls", {
enumerable: true,
get: function() {
return ToolbarControls;
}
});
const _react = /*#__PURE__*/ _interop_require_default(require("react"));
const _ = require("../../../..");
const _PopupButtonList = /*#__PURE__*/ _interop_require_wildcard(require("../../../../elements/Popup/PopupButtonList"));
const _ExternalLink = require("../../../../graphics/ExternalLink");
const _context = require("../../Context/context");
const _SizeInput = require("../SizeInput");
require("./index.scss");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
function _getRequireWildcardCache(nodeInterop) {
if (typeof WeakMap !== "function") return null;
var cacheBabelInterop = new WeakMap();
var cacheNodeInterop = new WeakMap();
return (_getRequireWildcardCache = function(nodeInterop) {
return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
})(nodeInterop);
}
function _interop_require_wildcard(obj, nodeInterop) {
if (!nodeInterop && obj && obj.__esModule) {
return obj;
}
if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
return {
default: obj
};
}
var cache = _getRequireWildcardCache(nodeInterop);
if (cache && cache.has(obj)) {
return cache.get(obj);
}
var newObj = {
__proto__: null
};
var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
for(var key in obj){
if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
if (desc && (desc.get || desc.set)) {
Object.defineProperty(newObj, key, desc);
} else {
newObj[key] = obj[key];
}
}
}
newObj.default = obj;
if (cache) {
cache.set(obj, newObj);
}
return newObj;
}
const baseClass = 'live-preview-toolbar-controls';
const zoomOptions = [
50,
75,
100,
125,
150,
200
];
const customOption = {
label: 'Custom',
value: 'custom'
};
const ToolbarControls = ()=>{
const { breakpoint, breakpoints, setBreakpoint, setPreviewWindowType, setZoom, url, zoom } = (0, _context.useLivePreviewContext)();
return /*#__PURE__*/ _react.default.createElement("div", {
className: baseClass
}, breakpoints?.length > 0 && /*#__PURE__*/ _react.default.createElement(_.Popup, {
className: `${baseClass}__breakpoint`,
button: /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement("span", null, breakpoints.find((bp)=>bp.name == breakpoint)?.label ?? customOption.label), " ", /*#__PURE__*/ _react.default.createElement(_.Chevron, {
className: `${baseClass}__chevron`
})),
render: ({ close })=>/*#__PURE__*/ _react.default.createElement(_PopupButtonList.ButtonGroup, null, /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, breakpoints.map((bp)=>/*#__PURE__*/ _react.default.createElement(_PopupButtonList.Button, {
key: bp.name,
active: bp.name == breakpoint,
onClick: ()=>{
setBreakpoint(bp.name);
close();
}
}, bp.label)), breakpoint === 'custom' && /*#__PURE__*/ _react.default.createElement(_PopupButtonList.Button, {
active: breakpoint == customOption.value,
onClick: ()=>{
setBreakpoint(customOption.value);
close();
}
}, customOption.label))),
showScrollbar: true,
verticalAlign: "bottom",
horizontalAlign: "right"
}), /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__device-size`
}, /*#__PURE__*/ _react.default.createElement(_SizeInput.PreviewFrameSizeInput, {
axis: "x"
}), /*#__PURE__*/ _react.default.createElement("span", {
className: `${baseClass}__size-divider`
}, /*#__PURE__*/ _react.default.createElement(_.X, null)), /*#__PURE__*/ _react.default.createElement(_SizeInput.PreviewFrameSizeInput, {
axis: "y"
})), /*#__PURE__*/ _react.default.createElement(_.Popup, {
className: `${baseClass}__zoom`,
button: /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement("span", null, zoom * 100, "%"), " ", /*#__PURE__*/ _react.default.createElement(_.Chevron, {
className: `${baseClass}__chevron`
})),
render: ({ close })=>/*#__PURE__*/ _react.default.createElement(_PopupButtonList.ButtonGroup, null, /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, zoomOptions.map((zoomValue)=>/*#__PURE__*/ _react.default.createElement(_PopupButtonList.Button, {
key: zoomValue,
active: zoom * 100 == zoomValue,
onClick: ()=>{
setZoom(zoomValue / 100);
close();
}
}, zoomValue, "%")))),
showScrollbar: true,
verticalAlign: "bottom",
horizontalAlign: "right"
}), /*#__PURE__*/ _react.default.createElement("a", {
className: `${baseClass}__external`,
href: url,
onClick: (e)=>{
e.preventDefault();
setPreviewWindowType('popup');
},
type: "button"
}, /*#__PURE__*/ _react.default.createElement(_ExternalLink.ExternalLinkIcon, null)));
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../../src/admin/components/views/LivePreview/Toolbar/Controls/index.tsx"],"sourcesContent":["import React from 'react'\n\nimport type { EditViewProps } from '../../../types'\n\nimport { Chevron, Popup, X } from '../../../..'\nimport * as PopupList from '../../../../elements/Popup/PopupButtonList'\nimport { ExternalLinkIcon } from '../../../../graphics/ExternalLink'\nimport { useLivePreviewContext } from '../../Context/context'\nimport { PreviewFrameSizeInput } from '../SizeInput'\nimport './index.scss'\n\nconst baseClass = 'live-preview-toolbar-controls'\nconst zoomOptions = [50, 75, 100, 125, 150, 200]\nconst customOption = {\n  label: 'Custom', // TODO: Add i18n to this string\n  value: 'custom',\n}\n\nexport const ToolbarControls: React.FC<EditViewProps> = () => {\n  const { breakpoint, breakpoints, setBreakpoint, setPreviewWindowType, setZoom, url, zoom } =\n    useLivePreviewContext()\n\n  return (\n    <div className={baseClass}>\n      {breakpoints?.length > 0 && (\n        <Popup\n          className={`${baseClass}__breakpoint`}\n          button={\n            <>\n              <span>\n                {breakpoints.find((bp) => bp.name == breakpoint)?.label ?? customOption.label}\n              </span>\n              &nbsp;\n              <Chevron className={`${baseClass}__chevron`} />\n            </>\n          }\n          render={({ close }) => (\n            <PopupList.ButtonGroup>\n              <React.Fragment>\n                {breakpoints.map((bp) => (\n                  <PopupList.Button\n                    key={bp.name}\n                    active={bp.name == breakpoint}\n                    onClick={() => {\n                      setBreakpoint(bp.name)\n                      close()\n                    }}\n                  >\n                    {bp.label}\n                  </PopupList.Button>\n                ))}\n                {/* Dynamically add this option so that it only appears when the width and height inputs are explicitly changed */}\n                {breakpoint === 'custom' && (\n                  <PopupList.Button\n                    active={breakpoint == customOption.value}\n                    onClick={() => {\n                      setBreakpoint(customOption.value)\n                      close()\n                    }}\n                  >\n                    {customOption.label}\n                  </PopupList.Button>\n                )}\n              </React.Fragment>\n            </PopupList.ButtonGroup>\n          )}\n          showScrollbar\n          verticalAlign=\"bottom\"\n          horizontalAlign=\"right\"\n        />\n      )}\n      <div className={`${baseClass}__device-size`}>\n        <PreviewFrameSizeInput axis=\"x\" />\n        <span className={`${baseClass}__size-divider`}>\n          <X />\n        </span>\n        <PreviewFrameSizeInput axis=\"y\" />\n      </div>\n      <Popup\n        className={`${baseClass}__zoom`}\n        button={\n          <>\n            <span>{zoom * 100}%</span>\n            &nbsp;\n            <Chevron className={`${baseClass}__chevron`} />\n          </>\n        }\n        render={({ close }) => (\n          <PopupList.ButtonGroup>\n            <React.Fragment>\n              {zoomOptions.map((zoomValue) => (\n                <PopupList.Button\n                  key={zoomValue}\n                  active={zoom * 100 == zoomValue}\n                  onClick={() => {\n                    setZoom(zoomValue / 100)\n                    close()\n                  }}\n                >\n                  {zoomValue}%\n                </PopupList.Button>\n              ))}\n            </React.Fragment>\n          </PopupList.ButtonGroup>\n        )}\n        showScrollbar\n        verticalAlign=\"bottom\"\n        horizontalAlign=\"right\"\n      />\n      <a\n        className={`${baseClass}__external`}\n        href={url}\n        onClick={(e) => {\n          e.preventDefault()\n          setPreviewWindowType('popup')\n        }}\n        type=\"button\"\n      >\n        <ExternalLinkIcon />\n      </a>\n    </div>\n  )\n}\n"],"names":["ToolbarControls","baseClass","zoomOptions","customOption","label","value","breakpoint","breakpoints","setBreakpoint","setPreviewWindowType","setZoom","url","zoom","useLivePreviewContext","div","className","length","Popup","button","span","find","bp","name","Chevron","render","close","PopupList","ButtonGroup","React","Fragment","map","Button","key","active","onClick","showScrollbar","verticalAlign","horizontalAlign","PreviewFrameSizeInput","axis","X","zoomValue","a","href","e","preventDefault","type","ExternalLinkIcon"],"mappings":";;;;+BAkBaA;;;eAAAA;;;8DAlBK;kBAIgB;yEACP;8BACM;yBACK;2BACA;QAC/B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEP,MAAMC,YAAY;AAClB,MAAMC,cAAc;IAAC;IAAI;IAAI;IAAK;IAAK;IAAK;CAAI;AAChD,MAAMC,eAAe;IACnBC,OAAO;IACPC,OAAO;AACT;AAEO,MAAML,kBAA2C;IACtD,MAAM,EAAEM,UAAU,EAAEC,WAAW,EAAEC,aAAa,EAAEC,oBAAoB,EAAEC,OAAO,EAAEC,GAAG,EAAEC,IAAI,EAAE,GACxFC,IAAAA,8BAAqB;IAEvB,qBACE,6BAACC;QAAIC,WAAWd;OACbM,aAAaS,SAAS,mBACrB,6BAACC,OAAK;QACJF,WAAW,CAAC,EAAEd,UAAU,YAAY,CAAC;QACrCiB,sBACE,0EACE,6BAACC,cACEZ,YAAYa,IAAI,CAAC,CAACC,KAAOA,GAAGC,IAAI,IAAIhB,aAAaF,SAASD,aAAaC,KAAK,GACxE,mBAEP,6BAACmB,SAAO;YAACR,WAAW,CAAC,EAAEd,UAAU,SAAS,CAAC;;QAG/CuB,QAAQ,CAAC,EAAEC,KAAK,EAAE,iBAChB,6BAACC,iBAAUC,WAAW,sBACpB,6BAACC,cAAK,CAACC,QAAQ,QACZtB,YAAYuB,GAAG,CAAC,CAACT,mBAChB,6BAACK,iBAAUK,MAAM;oBACfC,KAAKX,GAAGC,IAAI;oBACZW,QAAQZ,GAAGC,IAAI,IAAIhB;oBACnB4B,SAAS;wBACP1B,cAAca,GAAGC,IAAI;wBACrBG;oBACF;mBAECJ,GAAGjB,KAAK,IAIZE,eAAe,0BACd,6BAACoB,iBAAUK,MAAM;gBACfE,QAAQ3B,cAAcH,aAAaE,KAAK;gBACxC6B,SAAS;oBACP1B,cAAcL,aAAaE,KAAK;oBAChCoB;gBACF;eAECtB,aAAaC,KAAK;QAM7B+B,eAAAA;QACAC,eAAc;QACdC,iBAAgB;sBAGpB,6BAACvB;QAAIC,WAAW,CAAC,EAAEd,UAAU,aAAa,CAAC;qBACzC,6BAACqC,gCAAqB;QAACC,MAAK;sBAC5B,6BAACpB;QAAKJ,WAAW,CAAC,EAAEd,UAAU,cAAc,CAAC;qBAC3C,6BAACuC,GAAC,wBAEJ,6BAACF,gCAAqB;QAACC,MAAK;uBAE9B,6BAACtB,OAAK;QACJF,WAAW,CAAC,EAAEd,UAAU,MAAM,CAAC;QAC/BiB,sBACE,0EACE,6BAACC,cAAMP,OAAO,KAAI,MAAQ,mBAE1B,6BAACW,SAAO;YAACR,WAAW,CAAC,EAAEd,UAAU,SAAS,CAAC;;QAG/CuB,QAAQ,CAAC,EAAEC,KAAK,EAAE,iBAChB,6BAACC,iBAAUC,WAAW,sBACpB,6BAACC,cAAK,CAACC,QAAQ,QACZ3B,YAAY4B,GAAG,CAAC,CAACW,0BAChB,6BAACf,iBAAUK,MAAM;oBACfC,KAAKS;oBACLR,QAAQrB,OAAO,OAAO6B;oBACtBP,SAAS;wBACPxB,QAAQ+B,YAAY;wBACpBhB;oBACF;mBAECgB,WAAU;QAMrBN,eAAAA;QACAC,eAAc;QACdC,iBAAgB;sBAElB,6BAACK;QACC3B,WAAW,CAAC,EAAEd,UAAU,UAAU,CAAC;QACnC0C,MAAMhC;QACNuB,SAAS,CAACU;YACRA,EAAEC,cAAc;YAChBpC,qBAAqB;QACvB;QACAqC,MAAK;qBAEL,6BAACC,8BAAgB;AAIzB"}