@peak-ai/canvas 1.3.1 → 1.3.2
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/GrapesjsCanvas.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import _asyncToGenerator from"@babel/runtime/helpers/asyncToGenerator";import _extends from"@babel/runtime/helpers/extends";import _regeneratorRuntime from"@babel/runtime/regenerator";/* eslint-disable @typescript-eslint/no-explicit-any */import React,{useEffect,useRef}from"react";import grapesjs from"grapesjs";import"grapesjs/dist/css/grapes.min.css";import tailwind from"grapesjs-tailwind";import{TypesToRegister}from"./constants";import{toKebabCase}from"./helpers";import{createGrapesjsShadcnGenericPlugin}from"./plugins/grapejs-plugin";import{StyledEditor}from"./index.styles";import{tailwindCompiledCss}from"./helpers/css";import{jsx as _jsx,jsxs as _jsxs}from"react/jsx-runtime";function setComponentProperties(editor,isPreview){function setPropertiesRecursively(comp){comp.set({editable:!isPreview,draggable:!isPreview,droppable:!isPreview&&comp.getName()!=="Shadcn-generic",selectable:!isPreview,hoverable:!isPreview,highlightable:!isPreview,copyable:false,resizable:false,removable:!isPreview,badgable:false});if(!isPreview){comp.set("toolbar",[{attributes:{"class":"fa fa-arrows"},command:"tlb-move"},{attributes:{"class":"fa fa-trash"},command:"tlb-delete"}])}comp.components().forEach(setPropertiesRecursively)}if(isPreview){editor.runCommand("core:preview")}else{editor.stopCommand("core:preview")}var wrapper=editor.getWrapper();wrapper==null||wrapper.find("*").forEach(setPropertiesRecursively)}function convertStyles(stylesArray){return stylesArray.map(function(block){var selectors=Array.isArray(block.selectors)?block.selectors.join(", "):block.selectors;var declarations=Object.entries(block.style).map(function(_ref){var prop=_ref[0],value=_ref[1];return toKebabCase(prop)+": "+value+";"}).join(" ");return selectors+" { "+declarations+" }"}).join("\n")}function expandActions(node){var _node$componentProps;if(node.type==="shadcn-generic"&&node.componentName==="Actions"&&Array.isArray((_node$componentProps=node.componentProps)==null?void 0:_node$componentProps.actions)){var actions=node.componentProps.actions;return _extends({},node,{type:"div",classes:["dashboard-cards"].concat(node.classes||[]),componentName:undefined,componentProps:undefined,components:actions.map(function(action,i){var icon=action.icon,title=action.title,description=action.description;return{id:node.id+"--action-card-"+i,type:"shadcn-generic",componentName:"ActionCard",badgable:false,copyable:false,componentProps:{icon:icon,headerContent:title,bodyContent:description}}})})}if(Array.isArray(node.components)){return _extends({},node,{components:node.components.map(expandActions)})}return node}function setInteracting(renderedComponents,components,inProgress){components.forEach(function(component){var componentId=component.componentId,showLoader=component.showLoader;if(!showLoader){return}var gjsModel=renderedComponents[componentId];if(gjsModel){gjsModel.set("attributes",_extends({},gjsModel.get("attributes"),{interactionApiInProgress:inProgress}))}})}function GrapesjsCanvas(_ref2){var json=_ref2.json,_ref2$mode=_ref2.mode,mode=_ref2$mode===void 0?"preview":_ref2$mode,setEditor=_ref2.setEditor,performInteraction=_ref2.performInteraction;var editorRef=useRef(null);var editorInstance=useRef(null);var renderedComponents={};function performInteractionWrapper(_x){return _performInteractionWrapper.apply(this,arguments)}function _performInteractionWrapper(){_performInteractionWrapper=_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee(payload){var _editorInstance$curre;var updatedJson,result;return _regeneratorRuntime.wrap(function _callee$(_context){while(1)switch(_context.prev=_context.next){case 0:_context.next=2;return(_editorInstance$curre=editorInstance.current)==null?void 0:_editorInstance$curre.store();case 2:updatedJson=_context.sent;setInteracting(renderedComponents,payload.affectedComponents,true);_context.prev=4;_context.next=7;return performInteraction(_extends({},payload,{json:updatedJson}));case 7:result=_context.sent;Object.entries(result||{}).forEach(function(_ref4){var key=_ref4[0],value=_ref4[1];var model=renderedComponents[key];if(model){model.set("componentProps",_extends({},model.get("componentProps"),value))}});case 9:_context.prev=9;setInteracting(renderedComponents,payload.affectedComponents,false);return _context.finish(9);case 12:case"end":return _context.stop()}},_callee,null,[[4,,9,12]])}));return _performInteractionWrapper.apply(this,arguments)}useEffect(function(){var _json$pages,_json$pages$0$frames;if(!editorRef.current){return function(){// Cleanup if editorRef is not available
|
|
2
|
-
}}if(editorInstance.current){editorInstance.current.destroy();editorInstance.current=null}var currentMode=mode;var editor=grapesjs.init({container:editorRef.current,height:"100%",plugins:[tailwind,createGrapesjsShadcnGenericPlugin(currentMode,performInteractionWrapper,renderedComponents)],storageManager:{type:"none"},richTextEditor:{actions:["bold","italic","underline","strikethrough"]}});// Tailwind CSS rules aren't fully added to our component
|
|
2
|
+
}}if(editorInstance.current){editorInstance.current.destroy();editorInstance.current=null}var currentMode=mode;var editor=grapesjs.init({container:editorRef.current,height:"100%",plugins:[tailwind,createGrapesjsShadcnGenericPlugin(currentMode,performInteractionWrapper,renderedComponents)],storageManager:{type:"none"},richTextEditor:{actions:["bold","italic","underline","strikethrough"]},canvas:{customBadgeLabel:function customBadgeLabel(component){var tagName=component.get("tagName");return tagName==="body"?"":tagName||""}}});// Tailwind CSS rules aren't fully added to our component
|
|
3
3
|
// So, adding them from here!
|
|
4
4
|
editor.on("load",function(){var canvasHead=editor.Canvas.getDocument().head;var style=document.createElement("style");var fullCss="\n "+tailwindCompiledCss+"\n ::-webkit-scrollbar {\n width: 0px;\n height: 0px;\n }\n html, body {\n overflow: auto !important;\n -ms-overflow-style: none; /* IE and Edge */\n scrollbar-width: none; /* Firefox */\n }\n ";style.innerHTML=fullCss;style.setAttribute("type","text/css");canvasHead.appendChild(style)});editorInstance.current=editor;if(setEditor){setEditor(editor)}TypesToRegister.forEach(function(_ref3){var type=_ref3.type,tagName=_ref3.tagName;if(!editor.DomComponents.getType(type)){editor.DomComponents.addType(type,{model:{defaults:{tagName:tagName}},view:{}})}});if(json&&((_json$pages=json.pages)==null?void 0:_json$pages.length)>0&&((_json$pages$0$frames=json.pages[0].frames)==null?void 0:_json$pages$0$frames.length)>0){var raw=json.pages[0].frames[0].component;var processed=expandActions(raw);editor.setComponents(processed);var cssText=convertStyles(json.styles||[]);editor.setStyle(cssText)}editor.on("load",function(){setComponentProperties(editor,mode==="preview")});return function(){editor.destroy()};// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
5
5
|
},[json,mode]);return/*#__PURE__*/_jsxs(React.Fragment,{children:[/*#__PURE__*/_jsx(StyledEditor,{}),/*#__PURE__*/_jsx("div",{ref:editorRef})]})}export default GrapesjsCanvas;
|
package/GrapesjsCanvas.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GrapesjsCanvas.js","names":["React","useEffect","useRef","grapesjs","tailwind","TypesToRegister","toKebabCase","createGrapesjsShadcnGenericPlugin","StyledEditor","tailwindCompiledCss","jsx","_jsx","jsxs","_jsxs","setComponentProperties","editor","isPreview","setPropertiesRecursively","comp","set","editable","draggable","droppable","getName","selectable","hoverable","highlightable","copyable","resizable","removable","badgable","attributes","command","components","forEach","runCommand","stopCommand","wrapper","getWrapper","find","convertStyles","stylesArray","map","block","selectors","Array","isArray","join","declarations","Object","entries","style","_ref","prop","value","expandActions","node","_node$componentProps","type","componentName","componentProps","actions","_extends","classes","concat","undefined","action","i","icon","title","description","id","headerContent","bodyContent","setInteracting","renderedComponents","inProgress","component","componentId","showLoader","gjsModel","get","interactionApiInProgress","GrapesjsCanvas","_ref2","json","_ref2$mode","mode","setEditor","performInteraction","editorRef","editorInstance","performInteractionWrapper","_x","_performInteractionWrapper","apply","arguments","_asyncToGenerator","_regeneratorRuntime","mark","_callee","payload","_editorInstance$curre","updatedJson","result","wrap","_callee$","_context","prev","next","current","store","sent","affectedComponents","_ref4","key","model","finish","stop","_json$pages","_json$pages$0$frames","destroy","currentMode","init","container","height","plugins","storageManager","richTextEditor","on","canvasHead","Canvas","getDocument","head","document","createElement","fullCss","innerHTML","setAttribute","appendChild","_ref3","tagName","DomComponents","getType","addType","defaults","view","pages","length","frames","raw","processed","setComponents","cssText","styles","setStyle","Fragment","children","ref"],"sources":["../src/GrapesjsCanvas.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useEffect, useRef } from 'react';\nimport grapesjs, { Component, Editor } from 'grapesjs';\nimport 'grapesjs/dist/css/grapes.min.css';\nimport tailwind from 'grapesjs-tailwind';\nimport { TypesToRegister } from './constants';\nimport { toKebabCase } from './helpers';\nimport { createGrapesjsShadcnGenericPlugin } from './plugins/grapejs-plugin';\nimport { StyledEditor } from './index.styles';\nimport { tailwindCompiledCss } from './helpers/css';\n\ntype GrapesjsCanvasProps = {\n json: any;\n mode?: 'editor' | 'preview';\n setEditor: (editor: Editor) => void;\n performInteraction: (payload: Record<string, any>) => Promise<Record<string, any> | undefined>;\n};\n\nfunction setComponentProperties(editor: Editor, isPreview: boolean) {\n function setPropertiesRecursively(comp: Component) {\n comp.set({\n editable: !isPreview,\n draggable: !isPreview,\n droppable: !isPreview && comp.getName() !== 'Shadcn-generic',\n selectable: !isPreview,\n hoverable: !isPreview,\n highlightable: !isPreview,\n copyable: false,\n resizable: false,\n removable: !isPreview,\n badgable: false,\n });\n\n if (!isPreview) {\n comp.set('toolbar', [\n { attributes: { class: 'fa fa-arrows' }, command: 'tlb-move' },\n { attributes: { class: 'fa fa-trash' }, command: 'tlb-delete' },\n ]);\n }\n\n comp.components().forEach(setPropertiesRecursively);\n }\n\n if (isPreview) {\n editor.runCommand('core:preview');\n } else {\n editor.stopCommand('core:preview');\n }\n\n const wrapper = editor.getWrapper();\n wrapper?.find('*').forEach(setPropertiesRecursively);\n}\n\nfunction convertStyles(stylesArray: any[]): string {\n return stylesArray\n .map((block) => {\n const selectors = Array.isArray(block.selectors)\n ? block.selectors.join(', ')\n : block.selectors;\n const declarations = Object.entries(block.style)\n .map(([prop, value]) => `${toKebabCase(prop)}: ${value};`)\n .join(' ');\n\n return `${selectors} { ${declarations} }`;\n })\n .join('\\n');\n}\n\nfunction expandActions(node: any): any {\n if (\n node.type === 'shadcn-generic' &&\n node.componentName === 'Actions' &&\n Array.isArray(node.componentProps?.actions)\n ) {\n const { actions } = node.componentProps;\n\n return {\n ...node,\n type: 'div',\n classes: ['dashboard-cards', ...(node.classes || [])],\n componentName: undefined,\n componentProps: undefined,\n components: actions.map((action: any, i: number) => {\n const { icon, title, description } = action;\n\n return {\n id: `${node.id}--action-card-${i}`,\n type: 'shadcn-generic',\n componentName: 'ActionCard',\n badgable: false,\n copyable: false,\n componentProps: {\n icon,\n headerContent: title,\n bodyContent: description,\n },\n };\n }),\n };\n }\n\n if (Array.isArray(node.components)) {\n return {\n ...node,\n components: node.components.map(expandActions),\n };\n }\n\n return node;\n}\n\nfunction setInteracting(\n renderedComponents: Record<string, Component>,\n components: { componentId: string; showLoader: boolean }[],\n inProgress: boolean,\n) {\n components.forEach((component) => {\n const { componentId, showLoader } = component;\n\n if (!showLoader) {\n return;\n }\n\n const gjsModel = renderedComponents[componentId];\n\n if (gjsModel) {\n gjsModel.set('attributes', {\n ...gjsModel.get('attributes'),\n interactionApiInProgress: inProgress,\n });\n }\n });\n}\n\nfunction GrapesjsCanvas({\n json,\n mode = 'preview',\n setEditor,\n performInteraction,\n}: GrapesjsCanvasProps) {\n const editorRef = useRef<HTMLDivElement>(null);\n const editorInstance = useRef<any>(null);\n const renderedComponents: Record<string, Component> = {};\n\n async function performInteractionWrapper(payload: Record<string, any>) {\n const updatedJson = await editorInstance.current?.store();\n setInteracting(renderedComponents, payload.affectedComponents, true);\n\n try {\n const result = await performInteraction({\n ...payload,\n json: updatedJson,\n });\n\n Object.entries(result || {}).forEach(([key, value]) => {\n const model = renderedComponents[key];\n\n if (model) {\n model.set('componentProps', {\n ...model.get('componentProps'),\n ...value,\n });\n }\n });\n } finally {\n setInteracting(renderedComponents, payload.affectedComponents, false);\n }\n }\n\n useEffect(() => {\n if (!editorRef.current) {\n return () => {\n // Cleanup if editorRef is not available\n };\n }\n\n if (editorInstance.current) {\n editorInstance.current.destroy();\n editorInstance.current = null;\n }\n\n const currentMode = mode;\n\n const editor = grapesjs.init({\n container: editorRef.current,\n height: '100%',\n plugins: [\n tailwind,\n createGrapesjsShadcnGenericPlugin(\n currentMode,\n performInteractionWrapper,\n renderedComponents,\n ),\n ],\n storageManager: { type: 'none' },\n richTextEditor: {\n actions: ['bold', 'italic', 'underline', 'strikethrough'],\n },\n });\n\n // Tailwind CSS rules aren't fully added to our component\n // So, adding them from here!\n editor.on('load', () => {\n const canvasHead = editor.Canvas.getDocument().head;\n const style = document.createElement('style');\n const fullCss = `\n ${tailwindCompiledCss}\n ::-webkit-scrollbar {\n width: 0px;\n height: 0px;\n }\n html, body {\n overflow: auto !important;\n -ms-overflow-style: none; /* IE and Edge */\n scrollbar-width: none; /* Firefox */\n }\n `;\n style.innerHTML = fullCss;\n style.setAttribute('type', 'text/css');\n canvasHead.appendChild(style);\n });\n\n editorInstance.current = editor;\n\n if (setEditor) {\n setEditor(editor);\n }\n\n TypesToRegister.forEach(({ type, tagName }) => {\n if (!editor.DomComponents.getType(type)) {\n editor.DomComponents.addType(type, {\n model: {\n defaults: { tagName },\n },\n view: {},\n });\n }\n });\n\n if (json && json.pages?.length > 0 && json.pages[0].frames?.length > 0) {\n const raw = json.pages[0].frames[0].component;\n const processed = expandActions(raw);\n editor.setComponents(processed);\n\n const cssText = convertStyles(json.styles || []);\n editor.setStyle(cssText);\n }\n\n editor.on('load', () => {\n setComponentProperties(editor, mode === 'preview');\n });\n\n return () => {\n editor.destroy();\n };\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n }, [json, mode]);\n\n return (\n <React.Fragment>\n <StyledEditor />\n <div ref={editorRef} />\n </React.Fragment>\n );\n}\n\nexport default GrapesjsCanvas;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"GrapesjsCanvas.js","names":["React","useEffect","useRef","grapesjs","tailwind","TypesToRegister","toKebabCase","createGrapesjsShadcnGenericPlugin","StyledEditor","tailwindCompiledCss","jsx","_jsx","jsxs","_jsxs","setComponentProperties","editor","isPreview","setPropertiesRecursively","comp","set","editable","draggable","droppable","getName","selectable","hoverable","highlightable","copyable","resizable","removable","badgable","attributes","command","components","forEach","runCommand","stopCommand","wrapper","getWrapper","find","convertStyles","stylesArray","map","block","selectors","Array","isArray","join","declarations","Object","entries","style","_ref","prop","value","expandActions","node","_node$componentProps","type","componentName","componentProps","actions","_extends","classes","concat","undefined","action","i","icon","title","description","id","headerContent","bodyContent","setInteracting","renderedComponents","inProgress","component","componentId","showLoader","gjsModel","get","interactionApiInProgress","GrapesjsCanvas","_ref2","json","_ref2$mode","mode","setEditor","performInteraction","editorRef","editorInstance","performInteractionWrapper","_x","_performInteractionWrapper","apply","arguments","_asyncToGenerator","_regeneratorRuntime","mark","_callee","payload","_editorInstance$curre","updatedJson","result","wrap","_callee$","_context","prev","next","current","store","sent","affectedComponents","_ref4","key","model","finish","stop","_json$pages","_json$pages$0$frames","destroy","currentMode","init","container","height","plugins","storageManager","richTextEditor","canvas","customBadgeLabel","tagName","on","canvasHead","Canvas","getDocument","head","document","createElement","fullCss","innerHTML","setAttribute","appendChild","_ref3","DomComponents","getType","addType","defaults","view","pages","length","frames","raw","processed","setComponents","cssText","styles","setStyle","Fragment","children","ref"],"sources":["../src/GrapesjsCanvas.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport React, { useEffect, useRef } from 'react';\nimport grapesjs, { Component, Editor } from 'grapesjs';\nimport 'grapesjs/dist/css/grapes.min.css';\nimport tailwind from 'grapesjs-tailwind';\nimport { TypesToRegister } from './constants';\nimport { toKebabCase } from './helpers';\nimport { createGrapesjsShadcnGenericPlugin } from './plugins/grapejs-plugin';\nimport { StyledEditor } from './index.styles';\nimport { tailwindCompiledCss } from './helpers/css';\n\ntype GrapesjsCanvasProps = {\n json: any;\n mode?: 'editor' | 'preview';\n setEditor: (editor: Editor) => void;\n performInteraction: (payload: Record<string, any>) => Promise<Record<string, any> | undefined>;\n};\n\nfunction setComponentProperties(editor: Editor, isPreview: boolean) {\n function setPropertiesRecursively(comp: Component) {\n comp.set({\n editable: !isPreview,\n draggable: !isPreview,\n droppable: !isPreview && comp.getName() !== 'Shadcn-generic',\n selectable: !isPreview,\n hoverable: !isPreview,\n highlightable: !isPreview,\n copyable: false,\n resizable: false,\n removable: !isPreview,\n badgable: false,\n });\n\n if (!isPreview) {\n comp.set('toolbar', [\n { attributes: { class: 'fa fa-arrows' }, command: 'tlb-move' },\n { attributes: { class: 'fa fa-trash' }, command: 'tlb-delete' },\n ]);\n }\n\n comp.components().forEach(setPropertiesRecursively);\n }\n\n if (isPreview) {\n editor.runCommand('core:preview');\n } else {\n editor.stopCommand('core:preview');\n }\n\n const wrapper = editor.getWrapper();\n wrapper?.find('*').forEach(setPropertiesRecursively);\n}\n\nfunction convertStyles(stylesArray: any[]): string {\n return stylesArray\n .map((block) => {\n const selectors = Array.isArray(block.selectors)\n ? block.selectors.join(', ')\n : block.selectors;\n const declarations = Object.entries(block.style)\n .map(([prop, value]) => `${toKebabCase(prop)}: ${value};`)\n .join(' ');\n\n return `${selectors} { ${declarations} }`;\n })\n .join('\\n');\n}\n\nfunction expandActions(node: any): any {\n if (\n node.type === 'shadcn-generic' &&\n node.componentName === 'Actions' &&\n Array.isArray(node.componentProps?.actions)\n ) {\n const { actions } = node.componentProps;\n\n return {\n ...node,\n type: 'div',\n classes: ['dashboard-cards', ...(node.classes || [])],\n componentName: undefined,\n componentProps: undefined,\n components: actions.map((action: any, i: number) => {\n const { icon, title, description } = action;\n\n return {\n id: `${node.id}--action-card-${i}`,\n type: 'shadcn-generic',\n componentName: 'ActionCard',\n badgable: false,\n copyable: false,\n componentProps: {\n icon,\n headerContent: title,\n bodyContent: description,\n },\n };\n }),\n };\n }\n\n if (Array.isArray(node.components)) {\n return {\n ...node,\n components: node.components.map(expandActions),\n };\n }\n\n return node;\n}\n\nfunction setInteracting(\n renderedComponents: Record<string, Component>,\n components: { componentId: string; showLoader: boolean }[],\n inProgress: boolean,\n) {\n components.forEach((component) => {\n const { componentId, showLoader } = component;\n\n if (!showLoader) {\n return;\n }\n\n const gjsModel = renderedComponents[componentId];\n \n if (gjsModel) {\n gjsModel.set('attributes', {\n ...gjsModel.get('attributes'),\n interactionApiInProgress: inProgress,\n });\n }\n });\n}\n\nfunction GrapesjsCanvas({\n json,\n mode = 'preview',\n setEditor,\n performInteraction,\n}: GrapesjsCanvasProps) {\n const editorRef = useRef<HTMLDivElement>(null);\n const editorInstance = useRef<any>(null);\n const renderedComponents: Record<string, Component> = {};\n\n async function performInteractionWrapper(payload: Record<string, any>) {\n const updatedJson = await editorInstance.current?.store();\n setInteracting(renderedComponents, payload.affectedComponents, true);\n\n try {\n const result = await performInteraction({\n ...payload,\n json: updatedJson,\n });\n\n Object.entries(result || {}).forEach(([key, value]) => {\n const model = renderedComponents[key];\n\n if (model) {\n model.set('componentProps', {\n ...model.get('componentProps'),\n ...value,\n });\n }\n });\n } finally {\n setInteracting(renderedComponents, payload.affectedComponents, false);\n }\n }\n\n useEffect(() => {\n if (!editorRef.current) {\n return () => {\n // Cleanup if editorRef is not available\n };\n }\n\n if (editorInstance.current) {\n editorInstance.current.destroy();\n editorInstance.current = null;\n }\n\n const currentMode = mode;\n\n const editor = grapesjs.init({\n container: editorRef.current,\n height: '100%',\n plugins: [\n tailwind,\n createGrapesjsShadcnGenericPlugin(\n currentMode,\n performInteractionWrapper,\n renderedComponents,\n ),\n ],\n storageManager: { type: 'none' },\n richTextEditor: {\n actions: ['bold', 'italic', 'underline', 'strikethrough'],\n },\n canvas: {\n customBadgeLabel: (component) => {\n const tagName = component.get('tagName');\n \n return tagName === 'body' ? '' : (tagName || '');\n },\n },\n });\n\n // Tailwind CSS rules aren't fully added to our component\n // So, adding them from here!\n editor.on('load', () => {\n const canvasHead = editor.Canvas.getDocument().head;\n const style = document.createElement('style');\n const fullCss = `\n ${tailwindCompiledCss}\n ::-webkit-scrollbar {\n width: 0px;\n height: 0px;\n }\n html, body {\n overflow: auto !important;\n -ms-overflow-style: none; /* IE and Edge */\n scrollbar-width: none; /* Firefox */\n }\n `;\n style.innerHTML = fullCss;\n style.setAttribute('type', 'text/css');\n canvasHead.appendChild(style);\n });\n\n editorInstance.current = editor;\n\n if (setEditor) {\n setEditor(editor);\n }\n\n TypesToRegister.forEach(({ type, tagName }) => {\n if (!editor.DomComponents.getType(type)) {\n editor.DomComponents.addType(type, {\n model: {\n defaults: { tagName },\n },\n view: {},\n });\n }\n });\n\n if (json && json.pages?.length > 0 && json.pages[0].frames?.length > 0) {\n const raw = json.pages[0].frames[0].component;\n const processed = expandActions(raw);\n editor.setComponents(processed);\n\n const cssText = convertStyles(json.styles || []);\n editor.setStyle(cssText);\n }\n\n editor.on('load', () => {\n setComponentProperties(editor, mode === 'preview');\n });\n\n return () => {\n editor.destroy();\n };\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n }, [json, mode]);\n\n return (\n <React.Fragment>\n <StyledEditor />\n <div ref={editorRef} />\n </React.Fragment>\n );\n}\n\nexport default GrapesjsCanvas;\n"],"mappings":"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","ignoreList":[]}
|
package/index.styles.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{createGlobalStyle}from"styled-components";export var StyledEditor=createGlobalStyle([".gs-sidebar-left,.gs-sidebar-top,.gs-sidebar-right,.gjs-pn-panels,.gjs-pn-views,.gjs-off-prv,.gjs-pn-devices{display:none !important;}.gjs-cv-canvas{height:100% !important;width:100% !important;top:0 !important;}"]);
|
|
1
|
+
import{createGlobalStyle}from"styled-components";export var StyledEditor=createGlobalStyle([".gs-sidebar-left,.gs-sidebar-top,.gs-sidebar-right,.gjs-pn-panels,.gjs-pn-views,.gjs-off-prv,.gjs-pn-devices{display:none !important;}.gjs-badge-label{display:none !important;}.gjs-cv-canvas{height:100% !important;width:100% !important;top:0 !important;}.gjs-hovered,.gjs-selected,[data-gjs-type],[data-highlightable]{outline:none !important;}.gjs-highlighter,.gjs-highlighter-sel,.gjs-selected-parent,.gjs-toolbar{outline:none !important;border:none !important;box-shadow:none !important;}.gjs-frame{outline:none !important;border:none !important;}.gjs-selected::before,.gjs-selected::after,.gjs-hovered::before,.gjs-hovered::after{display:none !important;background:none !important;}.gjs-com-badge,.gjs-badge{display:none !important;}"]);
|
|
2
2
|
//# sourceMappingURL=index.styles.js.map
|
package/index.styles.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.styles.js","names":["createGlobalStyle","StyledEditor"],"sources":["../src/index.styles.ts"],"sourcesContent":["import { createGlobalStyle } from 'styled-components';\n\nexport const StyledEditor = createGlobalStyle`\n /* Hide GrapesJS panels */\n .gs-sidebar-left,\n .gs-sidebar-top,\n .gs-sidebar-right,\n .gjs-pn-panels,\n .gjs-pn-views,\n .gjs-off-prv,\n .gjs-pn-devices {\n display: none !important;\n }\n\n .gjs-cv-canvas {\n height: 100% !important;\n width: 100% !important;\n top: 0 !important;\n }\n`;\n"],"mappings":"AAAA,OAASA,iBAAiB,KAAQ,mBAAmB,CAErD,MAAO,IAAM,CAAAC,YAAY,CAAGD,iBAAiB,
|
|
1
|
+
{"version":3,"file":"index.styles.js","names":["createGlobalStyle","StyledEditor"],"sources":["../src/index.styles.ts"],"sourcesContent":["import { createGlobalStyle } from 'styled-components';\n\nexport const StyledEditor = createGlobalStyle`\n /* Hide GrapesJS panels */\n .gs-sidebar-left,\n .gs-sidebar-top,\n .gs-sidebar-right,\n .gjs-pn-panels,\n .gjs-pn-views,\n .gjs-off-prv,\n .gjs-pn-devices {\n display: none !important;\n }\n\n .gjs-badge-label {\n display: none !important;\n }\n\n .gjs-cv-canvas {\n height: 100% !important;\n width: 100% !important;\n top: 0 !important;\n }\n\n .gjs-hovered, \n .gjs-selected,\n [data-gjs-type],\n [data-highlightable] {\n outline: none !important;\n }\n\n .gjs-highlighter, \n .gjs-highlighter-sel,\n .gjs-selected-parent,\n .gjs-toolbar {\n outline: none !important;\n border: none !important;\n box-shadow: none !important;\n }\n\n .gjs-frame {\n outline: none !important;\n border: none !important;\n }\n\n .gjs-selected::before,\n .gjs-selected::after,\n .gjs-hovered::before,\n .gjs-hovered::after {\n display: none !important;\n background: none !important;\n }\n\n .gjs-com-badge,\n .gjs-badge {\n display: none !important;\n }\n`;\n"],"mappings":"AAAA,OAASA,iBAAiB,KAAQ,mBAAmB,CAErD,MAAO,IAAM,CAAAC,YAAY,CAAGD,iBAAiB,suBAuD5C","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import _asyncToGenerator from"@babel/runtime/helpers/asyncToGenerator";import _extends from"@babel/runtime/helpers/extends";import _objectWithoutPropertiesLoose from"@babel/runtime/helpers/objectWithoutPropertiesLoose";var _excluded=["gjsModel"],_excluded2=["isEditable","gjsModel"],_excluded3=["isEditable","gjsModel","performInteraction"],_excluded4=["gjsModel","performInteraction"],_excluded5=["gjsModel"];import _regeneratorRuntime from"@babel/runtime/regenerator";function _createForOfIteratorHelperLoose(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=_unsupportedIterableToArray(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var o=0;return function(){return o>=r.length?{done:!0}:{done:!1,value:r[o++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _unsupportedIterableToArray(r,a){if(r){if("string"==typeof r)return _arrayLikeToArray(r,a);var t={}.toString.call(r).slice(8,-1);return"Object"===t&&r.constructor&&(t=r.constructor.name),"Map"===t||"Set"===t?Array.from(r):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?_arrayLikeToArray(r,a):void 0}}function _arrayLikeToArray(r,a){(null==a||a>r.length)&&(a=r.length);for(var e=0,n=Array(a);e<a;e++)n[e]=r[e];return n}/* eslint-disable func-style *//* eslint-disable @typescript-eslint/no-empty-function *//* eslint-disable func-names *//* eslint-disable @typescript-eslint/no-explicit-any */import chroma from"chroma-js";import React,{useEffect,useState,useRef}from"react";import{theme}from"@peak-ai/ais-components/theme";import Markdown from"markdown-to-jsx";import{Loader2Icon}from"lucide-react";import{Card,CardHeader,CardTitle,CardDescription,CardContent,CardFooter}from"../../shadcn/components/ui/card";import{ChartContainer,ChartTooltip,ChartTooltipContent}from"../../shadcn/components/ui/chart";import{PieChart,Pie,BarChart,Bar,LineChart,Line,XAxis,YAxis,ResponsiveContainer,CartesianGrid,Legend}from"recharts";import{Table,TableHeader,TableRow,TableHead,TableBody,TableCell}from"../../shadcn/components/ui/table";import{cn}from"../../shadcn/utils";import{ScrollArea,ScrollBar}from"../../shadcn/components/ui/scroll-area";import{Tabs,TabsList,TabsTrigger,TabsContent}from"../../shadcn/components/ui/tabs";import{TableLoader,ChartLoader,CardLoader}from"../../shadcn/components/ui/skeleton";import{Button}from"../../shadcn/components/ui/button";import{jsx as _jsx,jsxs as _jsxs}from"react/jsx-runtime";var baseColors=[[theme.colors.Blue_100,theme.colors.Blue_30],[theme.colors.Purpley_100,theme.colors.Purpley_30],[theme.colors.Light_Bluish_Green,"#06601b"],[theme.colors.Wild_Strawberry,"#4d001c"]];function getAffectedComponentsWithLoader(affectedComponents,showLoader){if(showLoader===void 0){showLoader=true}return affectedComponents.map(function(component){return{componentId:component,showLoader:showLoader}})}function getNColors(n){var colors=[]
|
|
2
|
-
for(var _iterator=_createForOfIteratorHelperLoose(baseColors),_step;!(_step=_iterator()).done;){var baseColor=_step.value;// eslint-disable-next-line import/no-named-as-default-member
|
|
3
|
-
colors.push(chroma.scale(baseColor).mode("lab").colors(n))}function getOneColor(existing){var color=null;do{var base=colors[Math.floor(Math.random()*colors.length)];var selectedColorIndex=Math.floor(Math.random()*base.length);color=base[selectedColorIndex]}while(existing.includes(color));return color}var selectedColors=[];for(var i=0;i<n;i++){selectedColors.push(getOneColor(selectedColors))}return selectedColors}/* TODO: Loader remains */export function renderActionCard(props){var gjsModel=props.gjsModel,rest=_objectWithoutPropertiesLoose(props,_excluded);var _useState=useState(_extends({},props)),allData=_useState[0],setAllData=_useState[1];var _allData$headerConten=allData.headerContent,headerContent=_allData$headerConten===void 0?"Default Action Card Title":_allData$headerConten,icon=allData.icon,_allData$bodyContent=allData.bodyContent,bodyContent=_allData$bodyContent===void 0?"Default body content. Click to edit.":_allData$bodyContent;var _useState2=useState({interactionApiInProgress:false}),attributes=_useState2[0],setAttributes=_useState2[1];useEffect(function(){gjsModel.on("change:componentProps",function(){setAllData(_extends({},gjsModel.get("componentProps")))})},[]);useEffect(function(){gjsModel.on("change:attributes",function(){setAttributes(_extends({},gjsModel.get("attributes")))})},[]);var defaultClasses="bg-white text-black p-4 rounded-lg shadow border w-full max-w-full min-h-[180px]";return/*#__PURE__*/_jsx(Card,_extends({className:defaultClasses,isEditable:false,contentEditable:false},rest,{children:/*#__PURE__*/_jsx(CardContent,{className:"p-0",isEditable:false,contentEditable:false,children:/*#__PURE__*/_jsx("div",{className:"px-4 py-3",children:/*#__PURE__*/_jsxs("div",{className:"flex items-start",children:[/*#__PURE__*/_jsx("span",{className:"text-5xl mr-2","aria-hidden":"true",children:icon}),/*#__PURE__*/_jsxs("div",{className:"flex-1",children:[/*#__PURE__*/_jsx("div",{className:"text-xl font-semibold",children:headerContent}),/*#__PURE__*/_jsx("div",{className:"text-base leading-relaxed mt-1",children:bodyContent})]})]})})})}))}export function renderCard(props){var _props$isEditable=props.isEditable,isEditable=_props$isEditable===void 0?false:_props$isEditable,gjsModel=props.gjsModel,rest=_objectWithoutPropertiesLoose(props,_excluded2);var _useState3=useState(_extends({},props)),allData=_useState3[0],setAllData=_useState3[1];var headerContent=allData.headerContent,headerDescription=allData.headerDescription,bodyContent=allData.bodyContent,footerContent=allData.footerContent,footerClass=allData.footerClass,footerIcon=allData.footerIcon,contentMetadata=allData.contentMetadata,contentMetadataClass=allData.contentMetadataClass,className=allData.className;var _useState4=useState({interactionApiInProgress:false}),attributes=_useState4[0],setAttributes=_useState4[1];useEffect(function(){gjsModel.on("change:componentProps",function(){setAllData(_extends({},gjsModel.get("componentProps")))})},[]);useEffect(function(){gjsModel.on("change:attributes",function(){setAttributes(_extends({},gjsModel.get("attributes")))})},[]);var defaultClasses="bg-white text-black p-4 rounded-lg shadow border";var defaultFooterClasses="text-sm";var defaultContentMetadataClasses="text-xs";var mergedCardClassName=className?cn(defaultClasses,className):defaultClasses;var mergedFooterClassName=footerClass?cn(defaultFooterClasses,footerClass):defaultFooterClasses;var mergedContentMetadataClassName=contentMetadataClass?cn(defaultContentMetadataClasses,contentMetadataClass):defaultContentMetadataClasses;var hasFooterContent=!!((footerContent!=null?footerContent:"").trim()||(footerIcon!=null?footerIcon:"").trim());function getCardContent(){if(attributes.interactionApiInProgress){return/*#__PURE__*/_jsx(CardContent,{children:/*#__PURE__*/_jsx(CardLoader,{})})}return/*#__PURE__*/_jsxs(React.Fragment,{children:[/*#__PURE__*/_jsxs(CardHeader,{children:[/*#__PURE__*/_jsx(CardTitle,{"data-slot":"headerContent",contentEditable:isEditable,className:"text-lg",children:headerContent}),/*#__PURE__*/_jsx(CardDescription,{"data-slot":"headerDescription",contentEditable:isEditable,className:"text-sm",children:headerDescription})]}),/*#__PURE__*/_jsxs(CardContent,{"data-slot":"bodyContent",contentEditable:false,children:[/*#__PURE__*/_jsx("div",{className:"text-3xl font-semibold truncate",children:bodyContent}),contentMetadata&&/*#__PURE__*/_jsx("div",{className:mergedContentMetadataClassName,style:{color:"#2A44D4"},children:contentMetadata})]}),hasFooterContent&&/*#__PURE__*/_jsxs(CardFooter,{"data-slot":"footerContent",contentEditable:isEditable,className:mergedFooterClassName,children:[footerIcon&&/*#__PURE__*/_jsx("span",{className:"mr-2","aria-hidden":"true",children:footerIcon}),footerContent]})]})}return/*#__PURE__*/_jsx(Card,_extends({},rest,{className:mergedCardClassName,children:getCardContent()}))}function renderChartComponent(chartType,data,config){switch(chartType){case"pie":return/*#__PURE__*/_jsxs(PieChart,{children:[data.length>=20&&/*#__PURE__*/_jsx(ChartTooltip,{cursor:false,content:/*#__PURE__*/_jsx(ChartTooltipContent,{hideLabel:true})}),/*#__PURE__*/_jsx(Pie,{data:data,dataKey:config.dataKey,nameKey:config.nameKey,innerRadius:60,strokeWidth:10,label:data.length<20?function(_ref){var name=_ref.name,percent=_ref.percent;return name+": "+(percent*100).toFixed(0)+"%"}:undefined,labelLine:false})]});case"bar":config.dataKeys=config.dataKeys||[];return/*#__PURE__*/_jsxs(BarChart,_extends({data:data},config.chartUi,{children:[/*#__PURE__*/_jsx(CartesianGrid,{vertical:false}),/*#__PURE__*/_jsx(XAxis,{dataKey:config.xAxis}),/*#__PURE__*/_jsx(YAxis,{}),/*#__PURE__*/_jsx(Legend,{align:"left",wrapperStyle:{marginLeft:20}}),config.dataKeys.map(function(_ref2){var key=_ref2.key,name=_ref2.name,color=_ref2.color;return/*#__PURE__*/_jsx(Bar,{dataKey:key,fill:color!=null?color:"#4caf50",name:name,radius:2},key)}),/*#__PURE__*/_jsx(ChartTooltip,{cursor:false,content:/*#__PURE__*/_jsx(ChartTooltipContent,{indicator:"dashed"})})]}));case"line":config.dataKeys=config.dataKeys||[];return/*#__PURE__*/_jsxs(LineChart,{data:data,children:[/*#__PURE__*/_jsx(CartesianGrid,{vertical:false}),/*#__PURE__*/_jsx(XAxis,{dataKey:config.xAxis}),/*#__PURE__*/_jsx(YAxis,{}),/*#__PURE__*/_jsx(ChartTooltip,{cursor:false,content:/*#__PURE__*/_jsx(ChartTooltipContent,{indicator:"dashed"})}),config.dataKeys.map(function(_ref3){var key=_ref3.key,name=_ref3.name,color=_ref3.color;return/*#__PURE__*/_jsx(Line,{type:"monotone",dataKey:key,stroke:color!=null?color:"#4caf50",name:name},key)}),/*#__PURE__*/_jsx(Legend,{align:"left"})]});default:return/*#__PURE__*/_jsxs(PieChart,{children:[data.length>=20&&/*#__PURE__*/_jsx(ChartTooltip,{cursor:false,content:/*#__PURE__*/_jsx(ChartTooltipContent,{hideLabel:true})}),/*#__PURE__*/_jsx(Pie,{data:data,dataKey:config.dataKey,nameKey:config.nameKey,innerRadius:60,strokeWidth:10,label:data.length<20?function(_ref4){var name=_ref4.name,percent=_ref4.percent;return name+": "+(percent*100).toFixed(0)+"%"}:undefined,labelLine:false})]})}}export function renderChart(props){var _props$isEditable2=props.isEditable,isEditable=_props$isEditable2===void 0?false:_props$isEditable2,gjsModel=props.gjsModel,_props$performInterac=props.performInteraction,performInteraction=_props$performInterac===void 0?function(){}:_props$performInterac,rest=_objectWithoutPropertiesLoose(props,_excluded3);var _useState5=useState(_extends({},props)),allData=_useState5[0],setAllData=_useState5[1];var _useState6=useState({interactionApiInProgress:false}),attributes=_useState6[0],setAttributes=_useState6[1];useEffect(function(){gjsModel.on("change:componentProps",function(){setAllData(_extends({},gjsModel.get("componentProps")))})},[]);useEffect(function(){gjsModel.on("change:attributes",function(){setAttributes(_extends({},gjsModel.get("attributes")))})},[]);var _allData$config=allData.config,config=_allData$config===void 0?{}:_allData$config,_allData$chartType=allData.chartType,chartType=_allData$chartType===void 0?"pie":_allData$chartType,_allData$chartData=allData.chartData,chartData=_allData$chartData===void 0?[]:_allData$chartData,className=allData.className,_allData$title=allData.title,title=_allData$title===void 0?"Title":_allData$title,_allData$subTitle=allData.subTitle,subTitle=_allData$subTitle===void 0?"Subtitle":_allData$subTitle;var defaultClasses="aspect-auto h-[250px] w-full";var mergedClasses=className?cn(defaultClasses,className):defaultClasses;if(chartType==="pie"){var colors=getNColors(chartData.length);for(var i=0;i<chartData.length;i++){var data=chartData[i];if(!data.fill){data.fill=colors[i]}}}else if(!config.color){config.color=baseColors[Math.floor(Math.random()*baseColors.length)]}var width=undefined;if(chartType==="bar"){var totalDataPoints=chartData.length*config.dataKeys.length;config.chartUi={};if(totalDataPoints>15){width=totalDataPoints*15+config.dataKeys.length*3*chartData.length+chartData.length*10;config.chartUi={barSize:15,barGap:3,barCategoryGap:0.5,width:width}}}function interact(){var id=gjsModel.get("id");performInteraction({id:id,interactionType:"button",chartData:chartData,affectedComponents:getAffectedComponentsWithLoader([id],true),type:"chart"})}var chartUi=attributes.interactionApiInProgress?/*#__PURE__*/_jsx(ChartLoader,{}):/*#__PURE__*/_jsx(React.Fragment,{children:chartType==="bar"&&config.chartUi?/*#__PURE__*/_jsx(ResponsiveContainer,{width:"95%",height:250,children:/*#__PURE__*/_jsxs(ScrollArea,{children:[/*#__PURE__*/_jsx("div",{className:width?"min-w-["+width+"px] w-full":"w-full",children:/*#__PURE__*/_jsx(ChartContainer,_extends({},rest,{config:config,className:mergedClasses,children:renderChartComponent(chartType,chartData,config)}))}),/*#__PURE__*/_jsx(ScrollBar,{orientation:"horizontal"})]})}):/*#__PURE__*/_jsx(ResponsiveContainer,{width:"95%",height:250,children:/*#__PURE__*/_jsx(ChartContainer,_extends({},rest,{config:config,className:mergedClasses,children:renderChartComponent(chartType,chartData,config)}))})});return/*#__PURE__*/_jsxs(Card,{className:"shadow border mt-2 mb-2",children:[/*#__PURE__*/_jsxs(CardHeader,{children:[/*#__PURE__*/_jsx(CardTitle,{"data-slot":"title",contentEditable:isEditable,className:"text-2xl",children:title}),/*#__PURE__*/_jsx(CardDescription,{"data-slot":"subTitle",contentEditable:isEditable,className:"text-sm",children:subTitle})]}),/*#__PURE__*/_jsx(CardContent,{"data-slot":"bodyContent",contentEditable:false,className:"px-6",children:chartUi})]})}// Creating this separate component to manage loading state easily!
|
|
1
|
+
import _asyncToGenerator from"@babel/runtime/helpers/asyncToGenerator";import _extends from"@babel/runtime/helpers/extends";import _objectWithoutPropertiesLoose from"@babel/runtime/helpers/objectWithoutPropertiesLoose";var _excluded=["gjsModel"],_excluded2=["isEditable","gjsModel"],_excluded3=["isEditable","gjsModel","performInteraction"],_excluded4=["gjsModel","performInteraction"],_excluded5=["gjsModel"];import _regeneratorRuntime from"@babel/runtime/regenerator";function _createForOfIteratorHelperLoose(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=_unsupportedIterableToArray(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var o=0;return function(){return o>=r.length?{done:!0}:{done:!1,value:r[o++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _unsupportedIterableToArray(r,a){if(r){if("string"==typeof r)return _arrayLikeToArray(r,a);var t={}.toString.call(r).slice(8,-1);return"Object"===t&&r.constructor&&(t=r.constructor.name),"Map"===t||"Set"===t?Array.from(r):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?_arrayLikeToArray(r,a):void 0}}function _arrayLikeToArray(r,a){(null==a||a>r.length)&&(a=r.length);for(var e=0,n=Array(a);e<a;e++)n[e]=r[e];return n}/* eslint-disable func-style *//* eslint-disable @typescript-eslint/no-empty-function *//* eslint-disable func-names *//* eslint-disable @typescript-eslint/no-explicit-any */import chroma from"chroma-js";import React,{useEffect,useState,useRef}from"react";import{theme}from"@peak-ai/ais-components/theme";import Markdown from"markdown-to-jsx";import{Loader2Icon}from"lucide-react";import{Card,CardHeader,CardTitle,CardDescription,CardContent,CardFooter}from"../../shadcn/components/ui/card";import{ChartContainer,ChartTooltip,ChartTooltipContent}from"../../shadcn/components/ui/chart";import{PieChart,Pie,BarChart,Bar,LineChart,Line,XAxis,YAxis,ResponsiveContainer,CartesianGrid,Legend}from"recharts";import{Table,TableHeader,TableRow,TableHead,TableBody,TableCell}from"../../shadcn/components/ui/table";import{cn}from"../../shadcn/utils";import{ScrollArea,ScrollBar}from"../../shadcn/components/ui/scroll-area";import{Tabs,TabsList,TabsTrigger,TabsContent}from"../../shadcn/components/ui/tabs";import{TableLoader,ChartLoader,CardLoader}from"../../shadcn/components/ui/skeleton";import{Button}from"../../shadcn/components/ui/button";import{jsx as _jsx,jsxs as _jsxs}from"react/jsx-runtime";var baseColors=[[theme.colors.Blue_100,theme.colors.Blue_30],[theme.colors.Purpley_100,theme.colors.Purpley_30],[theme.colors.Light_Bluish_Green,"#06601b"],[theme.colors.Wild_Strawberry,"#4d001c"]];function getAffectedComponentsWithLoader(affectedComponents,showLoader){if(showLoader===void 0){showLoader=true}return affectedComponents.map(function(component){return{componentId:component,showLoader:showLoader}})}function getNColors(n){var colors=[];for(var _iterator=_createForOfIteratorHelperLoose(baseColors),_step;!(_step=_iterator()).done;){var baseColor=_step.value;// eslint-disable-next-line import/no-named-as-default-member
|
|
2
|
+
colors.push(chroma.scale(baseColor).mode("lab").colors(n))}function getOneColor(existing){var color=null;do{var base=colors[Math.floor(Math.random()*colors.length)];var selectedColorIndex=Math.floor(Math.random()*base.length);color=base[selectedColorIndex]}while(existing.includes(color));return color}var selectedColors=[];for(var i=0;i<n;i++){selectedColors.push(getOneColor(selectedColors))}return selectedColors}/* TODO: Loader remains */export function renderActionCard(props){var gjsModel=props.gjsModel,rest=_objectWithoutPropertiesLoose(props,_excluded);var _useState=useState(_extends({},props)),allData=_useState[0],setAllData=_useState[1];var _allData$headerConten=allData.headerContent,headerContent=_allData$headerConten===void 0?"Default Action Card Title":_allData$headerConten,icon=allData.icon,_allData$bodyContent=allData.bodyContent,bodyContent=_allData$bodyContent===void 0?"Default body content. Click to edit.":_allData$bodyContent;var _useState2=useState({interactionApiInProgress:false}),attributes=_useState2[0],setAttributes=_useState2[1];useEffect(function(){gjsModel.on("change:componentProps",function(){setAllData(_extends({},gjsModel.get("componentProps")))})},[]);useEffect(function(){gjsModel.on("change:attributes",function(){setAttributes(_extends({},gjsModel.get("attributes")))})},[]);var defaultClasses="bg-white text-black p-4 rounded-lg shadow border flex flex-col h-full";return/*#__PURE__*/_jsx(Card,_extends({className:defaultClasses,isEditable:false,contentEditable:false},rest,{children:/*#__PURE__*/_jsx(CardContent,{className:"p-0",isEditable:false,contentEditable:false,children:/*#__PURE__*/_jsx("div",{className:"px-4 py-3",children:/*#__PURE__*/_jsxs("div",{className:"flex items-start",children:[/*#__PURE__*/_jsx("span",{className:"text-5xl mr-2","aria-hidden":"true",children:icon}),/*#__PURE__*/_jsxs("div",{className:"flex-1",children:[/*#__PURE__*/_jsx("div",{className:"text-xl font-semibold",children:headerContent}),/*#__PURE__*/_jsx("div",{className:"text-base leading-relaxed mt-1",children:bodyContent})]})]})})})}))}export function renderCard(props){var _props$isEditable=props.isEditable,isEditable=_props$isEditable===void 0?false:_props$isEditable,gjsModel=props.gjsModel,rest=_objectWithoutPropertiesLoose(props,_excluded2);var _useState3=useState(_extends({},props)),allData=_useState3[0],setAllData=_useState3[1];var headerContent=allData.headerContent,headerDescription=allData.headerDescription,bodyContent=allData.bodyContent,footerContent=allData.footerContent,footerClass=allData.footerClass,footerIcon=allData.footerIcon,contentMetadata=allData.contentMetadata,contentMetadataClass=allData.contentMetadataClass,className=allData.className;var _useState4=useState({interactionApiInProgress:false}),attributes=_useState4[0],setAttributes=_useState4[1];useEffect(function(){gjsModel.on("change:componentProps",function(){setAllData(_extends({},gjsModel.get("componentProps")))})},[]);useEffect(function(){gjsModel.on("change:attributes",function(){setAttributes(_extends({},gjsModel.get("attributes")))})},[]);var defaultClasses="bg-white text-black p-4 rounded-lg shadow border flex flex-col h-full";var defaultFooterClasses="text-sm";var defaultContentMetadataClasses="text-xs";var mergedCardClassName=className?cn(defaultClasses,className):defaultClasses;var mergedFooterClassName=footerClass?cn(defaultFooterClasses,footerClass):defaultFooterClasses;var mergedContentMetadataClassName=contentMetadataClass?cn(defaultContentMetadataClasses,contentMetadataClass):defaultContentMetadataClasses;function getCardContent(){if(attributes.interactionApiInProgress){return/*#__PURE__*/_jsx(CardContent,{children:/*#__PURE__*/_jsx(CardLoader,{})})}return/*#__PURE__*/_jsxs(React.Fragment,{children:[/*#__PURE__*/_jsxs(CardHeader,{children:[/*#__PURE__*/_jsx(CardTitle,{"data-slot":"headerContent",contentEditable:isEditable,className:"text-lg",children:headerContent}),/*#__PURE__*/_jsx(CardDescription,{"data-slot":"headerDescription",contentEditable:isEditable,className:"text-sm",children:headerDescription})]}),/*#__PURE__*/_jsxs(CardContent,{"data-slot":"bodyContent",contentEditable:false,className:"flex-grow",children:[/*#__PURE__*/_jsx("div",{className:"text-3xl font-semibold truncate",children:bodyContent}),contentMetadata&&/*#__PURE__*/_jsx("div",{className:mergedContentMetadataClassName,style:{color:"#2A44D4"},children:contentMetadata})]}),/*#__PURE__*/_jsxs(CardFooter,{"data-slot":"footerContent",contentEditable:isEditable,className:cn(mergedFooterClassName),children:[footerIcon&&/*#__PURE__*/_jsx("span",{className:"mr-2","aria-hidden":"true",children:footerIcon}),footerContent]})]})}return/*#__PURE__*/_jsx(Card,_extends({},rest,{className:mergedCardClassName,children:getCardContent()}))}function renderChartComponent(chartType,data,config){switch(chartType){case"pie":return/*#__PURE__*/_jsxs(PieChart,{children:[data.length>=20&&/*#__PURE__*/_jsx(ChartTooltip,{cursor:false,content:/*#__PURE__*/_jsx(ChartTooltipContent,{hideLabel:true})}),/*#__PURE__*/_jsx(Pie,{data:data,dataKey:config.dataKey,nameKey:config.nameKey,innerRadius:60,strokeWidth:10,label:data.length<20?function(_ref){var name=_ref.name,percent=_ref.percent;return name+": "+(percent*100).toFixed(0)+"%"}:undefined,labelLine:false})]});case"bar":config.dataKeys=config.dataKeys||[];return/*#__PURE__*/_jsxs(BarChart,_extends({data:data},config.chartUi,{children:[/*#__PURE__*/_jsx(CartesianGrid,{vertical:false}),/*#__PURE__*/_jsx(XAxis,{dataKey:config.xAxis}),/*#__PURE__*/_jsx(YAxis,{}),/*#__PURE__*/_jsx(Legend,{align:"left",wrapperStyle:{marginLeft:20}}),config.dataKeys.map(function(_ref2){var key=_ref2.key,name=_ref2.name,color=_ref2.color;return/*#__PURE__*/_jsx(Bar,{dataKey:key,fill:color!=null?color:"#4caf50",name:name,radius:2},key)}),/*#__PURE__*/_jsx(ChartTooltip,{cursor:false,content:/*#__PURE__*/_jsx(ChartTooltipContent,{indicator:"dashed"})})]}));case"line":config.dataKeys=config.dataKeys||[];return/*#__PURE__*/_jsxs(LineChart,{data:data,children:[/*#__PURE__*/_jsx(CartesianGrid,{vertical:false}),/*#__PURE__*/_jsx(XAxis,{dataKey:config.xAxis}),/*#__PURE__*/_jsx(YAxis,{}),/*#__PURE__*/_jsx(ChartTooltip,{cursor:false,content:/*#__PURE__*/_jsx(ChartTooltipContent,{indicator:"dashed"})}),config.dataKeys.map(function(_ref3){var key=_ref3.key,name=_ref3.name,color=_ref3.color;return/*#__PURE__*/_jsx(Line,{type:"monotone",dataKey:key,stroke:color!=null?color:"#4caf50",name:name},key)}),/*#__PURE__*/_jsx(Legend,{align:"left"})]});default:return/*#__PURE__*/_jsxs(PieChart,{children:[data.length>=20&&/*#__PURE__*/_jsx(ChartTooltip,{cursor:false,content:/*#__PURE__*/_jsx(ChartTooltipContent,{hideLabel:true})}),/*#__PURE__*/_jsx(Pie,{data:data,dataKey:config.dataKey,nameKey:config.nameKey,innerRadius:60,strokeWidth:10,label:data.length<20?function(_ref4){var name=_ref4.name,percent=_ref4.percent;return name+": "+(percent*100).toFixed(0)+"%"}:undefined,labelLine:false})]})}}export function renderChart(props){var _props$isEditable2=props.isEditable,isEditable=_props$isEditable2===void 0?false:_props$isEditable2,gjsModel=props.gjsModel,_props$performInterac=props.performInteraction,performInteraction=_props$performInterac===void 0?function(){}:_props$performInterac,rest=_objectWithoutPropertiesLoose(props,_excluded3);var _useState5=useState(_extends({},props)),allData=_useState5[0],setAllData=_useState5[1];var _useState6=useState({interactionApiInProgress:false}),attributes=_useState6[0],setAttributes=_useState6[1];useEffect(function(){gjsModel.on("change:componentProps",function(){setAllData(_extends({},gjsModel.get("componentProps")))})},[]);useEffect(function(){gjsModel.on("change:attributes",function(){setAttributes(_extends({},gjsModel.get("attributes")))})},[]);var _allData$config=allData.config,config=_allData$config===void 0?{}:_allData$config,_allData$chartType=allData.chartType,chartType=_allData$chartType===void 0?"pie":_allData$chartType,_allData$chartData=allData.chartData,chartData=_allData$chartData===void 0?[]:_allData$chartData,className=allData.className,_allData$title=allData.title,title=_allData$title===void 0?"Title":_allData$title,_allData$subTitle=allData.subTitle,subTitle=_allData$subTitle===void 0?"Subtitle":_allData$subTitle;var defaultClasses="aspect-auto h-[250px] w-full";var mergedClasses=className?cn(defaultClasses,className):defaultClasses;if(chartType==="pie"){var colors=getNColors(chartData.length);for(var i=0;i<chartData.length;i++){var data=chartData[i];if(!data.fill){data.fill=colors[i]}}}else if(!config.color){config.color=baseColors[Math.floor(Math.random()*baseColors.length)]}var width=undefined;if(chartType==="bar"){var totalDataPoints=chartData.length*config.dataKeys.length;config.chartUi={};if(totalDataPoints>15){width=totalDataPoints*15+config.dataKeys.length*3*chartData.length+chartData.length*10;config.chartUi={barSize:15,barGap:3,barCategoryGap:0.5,width:width}}}function interact(){var id=gjsModel.get("id");performInteraction({id:id,interactionType:"button",chartData:chartData,affectedComponents:getAffectedComponentsWithLoader([id],true),type:"chart"})}var chartUi=attributes.interactionApiInProgress?/*#__PURE__*/_jsx(ChartLoader,{}):/*#__PURE__*/_jsx(React.Fragment,{children:chartType==="bar"&&config.chartUi?/*#__PURE__*/_jsx(ResponsiveContainer,{width:"95%",height:250,children:/*#__PURE__*/_jsxs(ScrollArea,{children:[/*#__PURE__*/_jsx("div",{className:width?"min-w-["+width+"px] w-full":"w-full",children:/*#__PURE__*/_jsx(ChartContainer,_extends({},rest,{config:config,className:mergedClasses,children:renderChartComponent(chartType,chartData,config)}))}),/*#__PURE__*/_jsx(ScrollBar,{orientation:"horizontal"})]})}):/*#__PURE__*/_jsx(ResponsiveContainer,{width:"95%",height:250,children:/*#__PURE__*/_jsx(ChartContainer,_extends({},rest,{config:config,className:mergedClasses,children:renderChartComponent(chartType,chartData,config)}))})});return/*#__PURE__*/_jsxs(Card,{className:"shadow border mt-2 mb-2",children:[/*#__PURE__*/_jsxs(CardHeader,{children:[/*#__PURE__*/_jsx(CardTitle,{"data-slot":"title",contentEditable:isEditable,className:"text-2xl",children:title}),/*#__PURE__*/_jsx(CardDescription,{"data-slot":"subTitle",contentEditable:isEditable,className:"text-sm",children:subTitle})]}),/*#__PURE__*/_jsx(CardContent,{"data-slot":"bodyContent",contentEditable:false,className:"px-6",children:chartUi})]})}// Creating this separate component to manage loading state easily!
|
|
4
3
|
function TableButton(props){var _useState7=useState(false),loading=_useState7[0],setLoading=_useState7[1];function onClick(){return _onClick.apply(this,arguments)}function _onClick(){_onClick=_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee(){return _regeneratorRuntime.wrap(function _callee$(_context){while(1)switch(_context.prev=_context.next){case 0:setLoading(true);_context.next=3;return props.onClick();case 3:setLoading(false);case 4:case"end":return _context.stop()}},_callee)}));return _onClick.apply(this,arguments)}var defaultClasses="mr-2";var mergedClasses=props.className?cn(defaultClasses,props.className):defaultClasses;return/*#__PURE__*/_jsx(Button,{className:mergedClasses,onClick:!props.isEditable?onClick:function(){},disabled:props.isDisabled||loading,variant:props.variant,size:"sm",children:loading?/*#__PURE__*/_jsx(Loader2Icon,{className:"animate-spin"}):props.text})}export function renderTable(props){var gjsModel=props.gjsModel,_props$performInterac2=props.performInteraction,performInteraction=_props$performInterac2===void 0?function(){}:_props$performInterac2,rest=_objectWithoutPropertiesLoose(props,_excluded4);var _useState8=useState(_extends({},props)),allData=_useState8[0],setAllData=_useState8[1];var _allData$data=allData.data,data=_allData$data===void 0?[]:_allData$data,_allData$headerMapper=allData.headerMapper,headerMapper=_allData$headerMapper===void 0?{}:_allData$headerMapper,className=allData.className,_allData$isEditable=allData.isEditable,isEditable=_allData$isEditable===void 0?false:_allData$isEditable,_allData$title2=allData.title,title=_allData$title2===void 0?"Title":_allData$title2,_allData$subTitle2=allData.subTitle,subTitle=_allData$subTitle2===void 0?"Subtitle":_allData$subTitle2,_allData$actions=allData.actions,actions=_allData$actions===void 0?[]:_allData$actions;var _useState9=useState({interactionApiInProgress:false}),attributes=_useState9[0],setAttributes=_useState9[1];useEffect(function(){gjsModel.on("change:componentProps",function(){setAllData(_extends({},gjsModel.get("componentProps")))})},[]);useEffect(function(){gjsModel.on("change:attributes",function(){setAttributes(_extends({},gjsModel.get("attributes")))})},[]);var parsedData=data.map(function(datum){var newData=_extends({},datum);delete newData.id;return newData});function takeRowAction(_x,_x2){return _takeRowAction.apply(this,arguments)}function _takeRowAction(){_takeRowAction=_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2(rowIndex,actionId){var id;return _regeneratorRuntime.wrap(function _callee2$(_context2){while(1)switch(_context2.prev=_context2.next){case 0:id=gjsModel.get("id");_context2.next=3;return performInteraction({id:actionId,interactionType:"tableButton",payload:{row:data[rowIndex],tableId:id},affectedComponents:[]});case 3:case"end":return _context2.stop()}},_callee2)}));return _takeRowAction.apply(this,arguments)}var headers=Object.keys(parsedData[0]||{}).map(function(header){return headerMapper[header]||header});if(actions.length>0){headers.push("")}var rows=parsedData.map(function(datum){return Object.values(datum)});var defaultClasses="aspect-auto h-[250px] w-full";var mergedClasses=className?cn(defaultClasses,className):defaultClasses;function renderActions(rowIndex,rowActions){if(!actions.length){return null}return/*#__PURE__*/_jsx(TableCell,{children:rowActions.map(function(action){return/*#__PURE__*/_jsx(TableButton,{className:action.className,isEditable:isEditable,onClick:function onClick(){return takeRowAction(rowIndex,action.id)},variant:action.variant,text:action.text},action.id)})})}var renderTableComponent=attributes.interactionApiInProgress?/*#__PURE__*/_jsx(TableLoader,{}):/*#__PURE__*/_jsxs(Table,_extends({},rest,{className:"caption-bottom text-sm "+mergedClasses,"data-slot":"table",children:[/*#__PURE__*/_jsx(TableHeader,{"data-slot":"table-header",className:"sticky top-0",children:/*#__PURE__*/_jsx(TableRow,{children:headers.map(function(head,idx){return/*#__PURE__*/_jsx(TableHead,{"data-slot":"table-header-"+idx,contentEditable:isEditable,children:head},idx)})})}),/*#__PURE__*/_jsx(TableBody,{"data-slot":"table-body",children:rows.map(function(row,rIdx){return/*#__PURE__*/_jsxs(TableRow,{"data-slot":"row-"+rIdx,className:"hover:bg-muted/50 border-b transition-colors",children:[row.map(function(cell,cIdx){return/*#__PURE__*/_jsx(TableCell,{"data-slot":"cell-"+rIdx+"-"+cIdx,className:"p-2 align-middle whitespace-nowrap",contentEditable:false,children:cell},cIdx)}),renderActions(rIdx,actions)]},rIdx)})})]}));var tableData=/*#__PURE__*/_jsxs(ScrollArea,{"data-slot":"table-container",className:mergedClasses,children:[renderTableComponent,/*#__PURE__*/_jsx(ScrollBar,{orientation:"horizontal"})]});return/*#__PURE__*/_jsxs(Card,{className:"shadow border",children:[/*#__PURE__*/_jsxs(CardHeader,{children:[/*#__PURE__*/_jsx(CardTitle,{"data-slot":"title",contentEditable:isEditable,className:"text-2xl",children:title}),/*#__PURE__*/_jsx(CardDescription,{"data-slot":"subTitle",contentEditable:isEditable,className:"text-sm",children:subTitle})]}),/*#__PURE__*/_jsx(CardContent,{"data-slot":"bodyContent",contentEditable:false,children:tableData})]})}export function renderTab(props){var tabsWidth=200;if(props.tabs.length>4){tabsWidth=150}return/*#__PURE__*/_jsxs(Tabs,{defaultValue:props.defaultValue,children:[/*#__PURE__*/_jsx("div",{className:"text-center mb-4",children:/*#__PURE__*/_jsx(TabsList,{className:"bg-gray-300",children:props.tabs.map(function(tab){return/*#__PURE__*/_jsx(TabsTrigger,{value:tab,className:"text-md w-["+tabsWidth+"px]",children:tab},tab)})})}),props.tabs.map(function(tab){return/*#__PURE__*/_jsx(TabsContent,{value:tab,className:"tabs-content"},tab)})]})}export function renderMarkdown(props){var gjsModel=props.gjsModel,rest=_objectWithoutPropertiesLoose(props,_excluded5);var _useState10=useState(_extends({},props)),allData=_useState10[0],setAllData=_useState10[1];var _useState11=useState({interactionApiInProgress:false}),attributes=_useState11[0],setAttributes=_useState11[1];useEffect(function(){gjsModel.on("change:componentProps",function(){setAllData(_extends({},gjsModel.get("componentProps")))})},[]);useEffect(function(){gjsModel.on("change:attributes",function(){setAttributes(_extends({},gjsModel.get("attributes")))})},[]);var _useState12=useState(false),isEditing=_useState12[0],setIsEditing=_useState12[1];var editRef=useRef(null);var startEditing=function startEditing(){setIsEditing(true);setTimeout(function(){setupEditor()},0)};var setupEditor=function setupEditor(){if(!editRef.current){return}var editor=editRef.current;editor.innerHTML="";editor.textContent=allData.summaryText;editor.focus()};// Save changes and exit editing mode
|
|
5
4
|
var saveChanges=function saveChanges(){if(!editRef.current){return}var content=editRef.current.innerText||"";setAllData(function(prev){return _extends({},prev,{summaryText:content})});setIsEditing(false);editRef.current.innerHTML=""};var markdownStyles={ul:{props:{className:"list-disc"}},h1:{props:{className:"text-4xl font-bold leading-[4rem]"}},h2:{props:{className:"text-3xl font-bold leading-[3rem]"}},h3:{props:{className:"text-2xl font-bold leading-[2rem]"}},h4:{props:{className:"text-xl font-bold leading-[2.5rem]"}},h5:{props:{className:"text-lg font-bold leading-[2.5rem]"}},h6:{props:{className:"text-base font-bold leading-[2rem]"}}};if(!allData.isEditable){return/*#__PURE__*/_jsx("div",_extends({className:"px-[1em]"},rest,{children:/*#__PURE__*/_jsx("div",{"data-slot":"summaryText",children:/*#__PURE__*/_jsx(Markdown,{options:{overrides:markdownStyles},children:allData.summaryText})})}))}return/*#__PURE__*/_jsx("div",_extends({className:"p-[1em]"},rest,{children:isEditing?/*#__PURE__*/_jsx("div",{ref:editRef,contentEditable:true,onBlur:saveChanges,"data-slot":"summaryText",className:"p-2 min-h-[100px] whitespace-pre-wrap",suppressContentEditableWarning:true,style:{whiteSpace:"pre-wrap",wordWrap:"break-word"}}):/*#__PURE__*/_jsx("div",{onClick:startEditing,"data-slot":"summaryText",style:{whiteSpace:"pre-wrap",wordWrap:"break-word"},children:/*#__PURE__*/_jsx(Markdown,{options:{overrides:markdownStyles},children:allData.summaryText})})}))}export function renderButton(props){var _props$isEditable3=props.isEditable,isEditable=_props$isEditable3===void 0?false:_props$isEditable3,gjsModel=props.gjsModel,_props$performInterac3=props.performInteraction,performInteraction=_props$performInterac3===void 0?function(){}:_props$performInterac3;var _useState13=useState(_extends({},props)),allData=_useState13[0],setAllData=_useState13[1];var _useState14=useState({interactionApiInProgress:false}),attributes=_useState14[0],setAttributes=_useState14[1];useEffect(function(){gjsModel.on("change:componentProps",function(){setAllData(_extends({},gjsModel.get("componentProps")))})},[]);useEffect(function(){gjsModel.on("change:attributes",function(){setAttributes(_extends({},gjsModel.get("attributes")))})},[]);var text=allData.text,icon=allData.icon,className=allData.className,payload=allData.payload,_allData$variant=allData.variant,variant=_allData$variant===void 0?"default":_allData$variant,_allData$size=allData.size,size=_allData$size===void 0?"sm":_allData$size,affectedComponents=allData.affectedComponents;function interact(){var id=gjsModel.get("id");performInteraction({id:id,interactionType:"button",affectedComponents:getAffectedComponentsWithLoader([id].concat(affectedComponents),true),payload:payload})}return/*#__PURE__*/_jsx(Button,{className:className,onClick:!isEditable?interact:function(){},disabled:attributes.interactionApiInProgress,variant:variant,size:size,contentEditable:isEditable,children:attributes.interactionApiInProgress?/*#__PURE__*/_jsx(Loader2Icon,{className:"animate-spin"}):text})}export function getRenderers(){return{ActionCard:renderActionCard,Card:renderCard,Chart:renderChart,Markdown:renderMarkdown,Table:renderTable,Tabs:renderTab,Button:renderButton}}
|
|
6
5
|
//# sourceMappingURL=render-components.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"render-components.js","names":["chroma","React","useEffect","useState","useRef","theme","Markdown","Loader2Icon","Card","CardHeader","CardTitle","CardDescription","CardContent","CardFooter","ChartContainer","ChartTooltip","ChartTooltipContent","PieChart","Pie","BarChart","Bar","LineChart","Line","XAxis","YAxis","ResponsiveContainer","CartesianGrid","Legend","Table","TableHeader","TableRow","TableHead","TableBody","TableCell","cn","ScrollArea","ScrollBar","Tabs","TabsList","TabsTrigger","TabsContent","TableLoader","ChartLoader","CardLoader","Button","jsx","_jsx","jsxs","_jsxs","baseColors","colors","Blue_100","Blue_30","Purpley_100","Purpley_30","Light_Bluish_Green","Wild_Strawberry","getAffectedComponentsWithLoader","affectedComponents","showLoader","map","component","componentId","getNColors","n","_iterator","_createForOfIteratorHelperLoose","_step","done","baseColor","value","push","scale","mode","getOneColor","existing","color","base","Math","floor","random","length","selectedColorIndex","includes","selectedColors","i","renderActionCard","props","gjsModel","rest","_objectWithoutPropertiesLoose","_excluded","_useState","_extends","allData","setAllData","_allData$headerConten","headerContent","icon","_allData$bodyContent","bodyContent","_useState2","interactionApiInProgress","attributes","setAttributes","on","get","defaultClasses","className","isEditable","contentEditable","children","renderCard","_props$isEditable","_excluded2","_useState3","headerDescription","footerContent","footerClass","footerIcon","contentMetadata","contentMetadataClass","_useState4","defaultFooterClasses","defaultContentMetadataClasses","mergedCardClassName","mergedFooterClassName","mergedContentMetadataClassName","hasFooterContent","trim","getCardContent","Fragment","style","renderChartComponent","chartType","data","config","cursor","content","hideLabel","dataKey","nameKey","innerRadius","strokeWidth","label","_ref","name","percent","toFixed","undefined","labelLine","dataKeys","chartUi","vertical","xAxis","align","wrapperStyle","marginLeft","_ref2","key","fill","radius","indicator","_ref3","type","stroke","_ref4","renderChart","_props$isEditable2","_props$performInterac","performInteraction","_excluded3","_useState5","_useState6","_allData$config","_allData$chartType","_allData$chartData","chartData","_allData$title","title","_allData$subTitle","subTitle","mergedClasses","width","totalDataPoints","barSize","barGap","barCategoryGap","interact","id","interactionType","height","orientation","TableButton","_useState7","loading","setLoading","onClick","_onClick","apply","arguments","_asyncToGenerator","_regeneratorRuntime","mark","_callee","wrap","_callee$","_context","prev","next","stop","disabled","isDisabled","variant","size","text","renderTable","_props$performInterac2","_excluded4","_useState8","_allData$data","_allData$headerMapper","headerMapper","_allData$isEditable","_allData$title2","_allData$subTitle2","_allData$actions","actions","_useState9","parsedData","datum","newData","takeRowAction","_x","_x2","_takeRowAction","_callee2","rowIndex","actionId","_callee2$","_context2","payload","row","tableId","headers","Object","keys","header","rows","values","renderActions","rowActions","action","renderTableComponent","head","idx","rIdx","cell","cIdx","tableData","renderTab","tabsWidth","tabs","defaultValue","tab","renderMarkdown","_excluded5","_useState10","_useState11","_useState12","isEditing","setIsEditing","editRef","startEditing","setTimeout","setupEditor","current","editor","innerHTML","textContent","summaryText","focus","saveChanges","innerText","markdownStyles","ul","h1","h2","h3","h4","h5","h6","options","overrides","ref","onBlur","suppressContentEditableWarning","whiteSpace","wordWrap","renderButton","_props$isEditable3","_props$performInterac3","_useState13","_useState14","_allData$variant","_allData$size","concat","getRenderers","ActionCard","Chart"],"sources":["../../../src/plugins/helpers/render-components.tsx"],"sourcesContent":["/* eslint-disable func-style */\n/* eslint-disable @typescript-eslint/no-empty-function */\n/* eslint-disable func-names */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport chroma from 'chroma-js';\nimport React, { useEffect, useState, JSX, useRef } from 'react';\n\nimport { theme } from '@peak-ai/ais-components/theme';\nimport Markdown from 'markdown-to-jsx';\nimport { Loader2Icon } from 'lucide-react';\n\nimport {\n Card,\n CardHeader,\n CardTitle,\n CardDescription,\n CardContent,\n CardFooter,\n} from '../../shadcn/components/ui/card';\nimport {\n ChartContainer,\n ChartTooltip,\n ChartTooltipContent,\n} from '../../shadcn/components/ui/chart';\n\nimport {\n PieChart,\n Pie,\n BarChart,\n Bar,\n LineChart,\n Line,\n XAxis,\n YAxis,\n ResponsiveContainer,\n CartesianGrid,\n Legend,\n} from 'recharts';\nimport {\n Table,\n TableHeader,\n TableRow,\n TableHead,\n TableBody,\n TableCell,\n} from '../../shadcn/components/ui/table';\nimport { cn } from '../../shadcn/utils';\nimport { ScrollArea, ScrollBar } from '../../shadcn/components/ui/scroll-area';\nimport { Tabs, TabsList, TabsTrigger, TabsContent } from '../../shadcn/components/ui/tabs';\nimport { TableLoader, ChartLoader, CardLoader } from '../../shadcn/components/ui/skeleton';\nimport { Button } from '../../shadcn/components/ui/button';\n\nconst baseColors = [\n [theme.colors.Blue_100, theme.colors.Blue_30],\n [theme.colors.Purpley_100, theme.colors.Purpley_30],\n [theme.colors.Light_Bluish_Green, '#06601b'],\n [theme.colors.Wild_Strawberry, '#4d001c'],\n];\n\nfunction getAffectedComponentsWithLoader(affectedComponents: Array<string>, showLoader = true) {\n return affectedComponents.map((component) => ({\n componentId: component,\n showLoader,\n }));\n}\n\nfunction getNColors(n: number) {\n const colors: Array<string[]> = [];\n // const pallette = pallettes[Math.floor(Math.random() * pallettes.length)];\n\n for (const baseColor of baseColors) {\n // eslint-disable-next-line import/no-named-as-default-member\n colors.push(chroma.scale(baseColor).mode('lab').colors(n));\n }\n\n function getOneColor(existing: Array<string>) {\n let color: null | string = null;\n\n do {\n const base = colors[Math.floor(Math.random() * colors.length)];\n const selectedColorIndex = Math.floor(Math.random() * base.length);\n color = base[selectedColorIndex];\n } while (existing.includes(color));\n\n return color as string;\n }\n\n const selectedColors: Array<string> = [];\n\n for (let i = 0; i < n; i++) {\n selectedColors.push(getOneColor(selectedColors));\n }\n\n return selectedColors;\n}\n\n/* TODO: Loader remains */\nexport function renderActionCard(props: any): JSX.Element {\n const { gjsModel, ...rest } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const {\n headerContent = 'Default Action Card Title',\n icon,\n bodyContent = 'Default body content. Click to edit.',\n } = allData;\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const defaultClasses =\n 'bg-white text-black p-4 rounded-lg shadow border w-full max-w-full min-h-[180px]';\n\n return (\n <Card className={defaultClasses} isEditable={false} contentEditable={false} {...rest}>\n <CardContent className=\"p-0\" isEditable={false} contentEditable={false}>\n <div className=\"px-4 py-3\">\n <div className=\"flex items-start\">\n <span className=\"text-5xl mr-2\" aria-hidden=\"true\">\n {icon}\n </span>\n\n <div className=\"flex-1\">\n <div className=\"text-xl font-semibold\">{headerContent}</div>\n <div className=\"text-base leading-relaxed mt-1\">{bodyContent}</div>\n </div>\n </div>\n </div>\n </CardContent>\n </Card>\n );\n}\n\nexport function renderCard(props: any): JSX.Element {\n const { isEditable = false, gjsModel, ...rest } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const {\n headerContent,\n headerDescription,\n bodyContent,\n footerContent,\n footerClass,\n footerIcon,\n contentMetadata,\n contentMetadataClass,\n className,\n } = allData;\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const defaultClasses = 'bg-white text-black p-4 rounded-lg shadow border';\n const defaultFooterClasses = 'text-sm';\n const defaultContentMetadataClasses = 'text-xs';\n const mergedCardClassName = className ? cn(defaultClasses, className) : defaultClasses;\n const mergedFooterClassName = footerClass\n ? cn(defaultFooterClasses, footerClass)\n : defaultFooterClasses;\n const mergedContentMetadataClassName = contentMetadataClass\n ? cn(defaultContentMetadataClasses, contentMetadataClass)\n : defaultContentMetadataClasses;\n\n const hasFooterContent = !!((footerContent ?? '').trim() || (footerIcon ?? '').trim());\n\n function getCardContent() {\n if (attributes.interactionApiInProgress) {\n return (\n <CardContent>\n <CardLoader />\n </CardContent>\n );\n }\n\n return (\n <React.Fragment>\n <CardHeader>\n <CardTitle data-slot=\"headerContent\" contentEditable={isEditable} className=\"text-lg\">\n {headerContent}\n </CardTitle>\n <CardDescription\n data-slot=\"headerDescription\"\n contentEditable={isEditable}\n className=\"text-sm\"\n >\n {headerDescription}\n </CardDescription>\n </CardHeader>\n\n <CardContent data-slot=\"bodyContent\" contentEditable={false}>\n <div className=\"text-3xl font-semibold truncate\">{bodyContent}</div>\n {contentMetadata && (\n <div className={mergedContentMetadataClassName} style={{ color: '#2A44D4' }}>\n {contentMetadata}\n </div>\n )}\n </CardContent>\n\n {hasFooterContent && (\n <CardFooter\n data-slot=\"footerContent\"\n contentEditable={isEditable}\n className={mergedFooterClassName}\n >\n {footerIcon && (\n <span className=\"mr-2\" aria-hidden=\"true\">\n {footerIcon}\n </span>\n )}\n {footerContent}\n </CardFooter>\n )}\n </React.Fragment>\n );\n }\n\n return (\n <Card {...rest} className={mergedCardClassName}>\n {getCardContent()}\n </Card>\n );\n}\n\nfunction renderChartComponent(chartType: string, data: any, config: any): JSX.Element {\n switch (chartType) {\n case 'pie':\n return (\n <PieChart>\n {data.length >= 20 && (\n <ChartTooltip cursor={false} content={<ChartTooltipContent hideLabel />} />\n )}\n <Pie\n data={data}\n dataKey={config.dataKey}\n nameKey={config.nameKey}\n innerRadius={60}\n strokeWidth={10}\n label={\n data.length < 20\n ? ({ name, percent }) => `${name}: ${(percent * 100).toFixed(0)}%`\n : undefined\n }\n labelLine={false}\n />\n </PieChart>\n );\n case 'bar':\n config.dataKeys = config.dataKeys || [];\n\n return (\n <BarChart data={data} {...config.chartUi}>\n <CartesianGrid vertical={false} />\n <XAxis dataKey={config.xAxis} />\n <YAxis />\n <Legend align=\"left\" wrapperStyle={{ marginLeft: 20 }} />\n {config.dataKeys.map(\n ({ key, name, color }: { key: string; name: string; color: string }) => {\n return (\n <Bar dataKey={key} fill={color ?? '#4caf50'} name={name} key={key} radius={2} />\n );\n },\n )}\n <ChartTooltip cursor={false} content={<ChartTooltipContent indicator=\"dashed\" />} />\n </BarChart>\n );\n case 'line':\n config.dataKeys = config.dataKeys || [];\n\n return (\n <LineChart data={data}>\n <CartesianGrid vertical={false} />\n <XAxis dataKey={config.xAxis} />\n <YAxis />\n <ChartTooltip cursor={false} content={<ChartTooltipContent indicator=\"dashed\" />} />\n {config.dataKeys.map(\n ({ key, name, color }: { key: string; name: string; color: string }) => {\n return (\n <Line\n type=\"monotone\"\n dataKey={key}\n stroke={color ?? '#4caf50'}\n name={name}\n key={key}\n />\n );\n },\n )}\n <Legend align=\"left\" />\n </LineChart>\n );\n default:\n return (\n <PieChart>\n {data.length >= 20 && (\n <ChartTooltip cursor={false} content={<ChartTooltipContent hideLabel />} />\n )}\n <Pie\n data={data}\n dataKey={config.dataKey}\n nameKey={config.nameKey}\n innerRadius={60}\n strokeWidth={10}\n label={\n data.length < 20\n ? ({ name, percent }) => `${name}: ${(percent * 100).toFixed(0)}%`\n : undefined\n }\n labelLine={false}\n />\n </PieChart>\n );\n }\n}\n\nexport function renderChart(props: any): JSX.Element {\n const { isEditable = false, gjsModel, performInteraction = () => {}, ...rest } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const {\n config = {},\n chartType = 'pie',\n chartData = [],\n className,\n title = 'Title',\n subTitle = 'Subtitle',\n } = allData;\n\n const defaultClasses = 'aspect-auto h-[250px] w-full';\n const mergedClasses = className ? cn(defaultClasses, className) : defaultClasses;\n\n if (chartType === 'pie') {\n const colors = getNColors(chartData.length);\n\n for (let i = 0; i < chartData.length; i++) {\n const data = chartData[i];\n\n if (!data.fill) {\n data.fill = colors[i];\n }\n }\n } else if (!config.color) {\n config.color = baseColors[Math.floor(Math.random() * baseColors.length)];\n }\n\n let width: number | undefined = undefined;\n\n if (chartType === 'bar') {\n const totalDataPoints = chartData.length * config.dataKeys.length;\n config.chartUi = {};\n\n if (totalDataPoints > 15) {\n width =\n totalDataPoints * 15 +\n config.dataKeys.length * 3 * chartData.length +\n chartData.length * 10;\n config.chartUi = {\n barSize: 15,\n barGap: 3,\n barCategoryGap: 0.5,\n width,\n };\n }\n }\n\n function interact() {\n const id = gjsModel.get('id');\n performInteraction({\n id,\n interactionType: 'button',\n chartData,\n affectedComponents: getAffectedComponentsWithLoader([id], true),\n type: 'chart',\n });\n }\n\n const chartUi = attributes.interactionApiInProgress ? (\n <ChartLoader />\n ) : (\n <React.Fragment>\n {chartType === 'bar' && config.chartUi ? (\n <ResponsiveContainer width=\"95%\" height={250}>\n <ScrollArea>\n <div className={width ? `min-w-[${width}px] w-full` : 'w-full'}>\n <ChartContainer {...rest} config={config} className={mergedClasses}>\n {renderChartComponent(chartType, chartData, config)}\n </ChartContainer>\n </div>\n <ScrollBar orientation=\"horizontal\" />\n </ScrollArea>\n </ResponsiveContainer>\n ) : (\n <ResponsiveContainer width=\"95%\" height={250}>\n <ChartContainer {...rest} config={config} className={mergedClasses}>\n {renderChartComponent(chartType, chartData, config)}\n </ChartContainer>\n </ResponsiveContainer>\n )}\n </React.Fragment>\n );\n\n return (\n <Card className=\"shadow border mt-2 mb-2\">\n <CardHeader>\n <CardTitle data-slot=\"title\" contentEditable={isEditable} className=\"text-2xl\">\n {title}\n </CardTitle>\n <CardDescription data-slot=\"subTitle\" contentEditable={isEditable} className=\"text-sm\">\n {subTitle}\n </CardDescription>\n </CardHeader>\n <CardContent data-slot=\"bodyContent\" contentEditable={false} className=\"px-6\">\n {chartUi}\n </CardContent>\n </Card>\n );\n}\n\n// Creating this separate component to manage loading state easily!\nfunction TableButton(props: any) {\n const [loading, setLoading] = useState(false);\n\n async function onClick() {\n setLoading(true);\n await props.onClick();\n setLoading(false);\n }\n\n const defaultClasses = 'mr-2';\n const mergedClasses = props.className ? cn(defaultClasses, props.className) : defaultClasses;\n\n return (\n <Button\n className={mergedClasses}\n onClick={!props.isEditable ? onClick : () => {}}\n disabled={props.isDisabled || loading}\n variant={props.variant}\n size=\"sm\"\n >\n {loading ? <Loader2Icon className=\"animate-spin\" /> : props.text}\n </Button>\n );\n}\n\nexport function renderTable(props: any): JSX.Element {\n const { gjsModel, performInteraction = () => {}, ...rest } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const {\n data = [],\n headerMapper = {},\n className,\n isEditable = false,\n title = 'Title',\n subTitle = 'Subtitle',\n actions = [],\n } = allData;\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const parsedData = data.map((datum: any) => {\n const newData = {\n ...datum,\n };\n\n delete newData.id;\n\n return newData;\n });\n\n async function takeRowAction(rowIndex: number, actionId: string) {\n const id = gjsModel.get('id');\n\n await performInteraction({\n id: actionId,\n interactionType: 'tableButton',\n payload: {\n row: data[rowIndex],\n tableId: id,\n },\n affectedComponents: [],\n });\n }\n\n const headers = Object.keys(parsedData[0] || {}).map((header) => headerMapper[header] || header);\n\n if (actions.length > 0) {\n headers.push('');\n }\n\n const rows = parsedData.map((datum: any) => Object.values(datum));\n\n const defaultClasses = 'aspect-auto h-[250px] w-full';\n const mergedClasses = className ? cn(defaultClasses, className) : defaultClasses;\n\n function renderActions(rowIndex: number, rowActions: Array<Record<string, any>>) {\n if (!actions.length) {\n return null;\n }\n\n return (\n <TableCell>\n {rowActions.map((action) => {\n return (\n <TableButton\n className={action.className}\n isEditable={isEditable}\n onClick={() => takeRowAction(rowIndex, action.id)}\n variant={action.variant}\n key={action.id}\n text={action.text}\n />\n );\n })}\n </TableCell>\n );\n }\n\n const renderTableComponent = attributes.interactionApiInProgress ? (\n <TableLoader />\n ) : (\n <Table {...rest} className={`caption-bottom text-sm ${mergedClasses}`} data-slot=\"table\">\n <TableHeader data-slot=\"table-header\" className=\"sticky top-0\">\n <TableRow>\n {headers.map((head: string, idx: number) => (\n <TableHead key={idx} data-slot={`table-header-${idx}`} contentEditable={isEditable}>\n {head}\n </TableHead>\n ))}\n </TableRow>\n </TableHeader>\n <TableBody data-slot=\"table-body\">\n {rows.map((row: any[], rIdx: number) => (\n <TableRow\n key={rIdx}\n data-slot={`row-${rIdx}`}\n className=\"hover:bg-muted/50 border-b transition-colors\"\n >\n {row.map((cell: string, cIdx: number) => (\n <TableCell\n key={cIdx}\n data-slot={`cell-${rIdx}-${cIdx}`}\n className=\"p-2 align-middle whitespace-nowrap\"\n contentEditable={false}\n >\n {cell}\n </TableCell>\n ))}\n {renderActions(rIdx, actions)}\n </TableRow>\n ))}\n </TableBody>\n </Table>\n );\n\n const tableData = (\n <ScrollArea data-slot=\"table-container\" className={mergedClasses}>\n {renderTableComponent}\n <ScrollBar orientation=\"horizontal\" />\n </ScrollArea>\n );\n\n return (\n <Card className=\"shadow border\">\n <CardHeader>\n <CardTitle data-slot=\"title\" contentEditable={isEditable} className=\"text-2xl\">\n {title}\n </CardTitle>\n <CardDescription data-slot=\"subTitle\" contentEditable={isEditable} className=\"text-sm\">\n {subTitle}\n </CardDescription>\n </CardHeader>\n <CardContent data-slot=\"bodyContent\" contentEditable={false}>\n {tableData}\n </CardContent>\n </Card>\n );\n}\n\nexport function renderTab(props: any): JSX.Element {\n let tabsWidth = 200;\n\n if (props.tabs.length > 4) {\n tabsWidth = 150;\n }\n\n return (\n <Tabs defaultValue={props.defaultValue}>\n <div className=\"text-center mb-4\">\n <TabsList className=\"bg-gray-300\">\n {props.tabs.map((tab: string) => (\n <TabsTrigger value={tab} key={tab} className={`text-md w-[${tabsWidth}px]`}>\n {tab}\n </TabsTrigger>\n ))}\n </TabsList>\n </div>\n {props.tabs.map((tab: string) => (\n <TabsContent value={tab} className=\"tabs-content\" key={tab} />\n ))}\n </Tabs>\n );\n}\n\nexport function renderMarkdown(props: any): JSX.Element {\n const { gjsModel, ...rest } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const [isEditing, setIsEditing] = useState(false);\n const editRef = useRef<HTMLDivElement>(null);\n\n const startEditing = () => {\n setIsEditing(true);\n setTimeout(() => {\n setupEditor();\n }, 0);\n };\n\n const setupEditor = () => {\n if (!editRef.current) {\n return;\n }\n\n const editor = editRef.current;\n editor.innerHTML = '';\n editor.textContent = allData.summaryText;\n editor.focus();\n };\n\n // Save changes and exit editing mode\n const saveChanges = () => {\n if (!editRef.current) {\n return;\n }\n\n const content = editRef.current.innerText || '';\n setAllData((prev: Record<string, any>) => ({\n ...prev,\n summaryText: content,\n }));\n setIsEditing(false);\n editRef.current.innerHTML = '';\n };\n\n const markdownStyles = {\n ul: { props: { className: 'list-disc' } },\n h1: { props: { className: 'text-4xl font-bold leading-[4rem]' } },\n h2: { props: { className: 'text-3xl font-bold leading-[3rem]' } },\n h3: { props: { className: 'text-2xl font-bold leading-[2rem]' } },\n h4: { props: { className: 'text-xl font-bold leading-[2.5rem]' } },\n h5: { props: { className: 'text-lg font-bold leading-[2.5rem]' } },\n h6: { props: { className: 'text-base font-bold leading-[2rem]' } },\n };\n\n if (!allData.isEditable) {\n return (\n <div className=\"px-[1em]\" {...rest}>\n <div data-slot=\"summaryText\">\n <Markdown options={{ overrides: markdownStyles }}>{allData.summaryText}</Markdown>\n </div>\n </div>\n );\n }\n\n return (\n <div className=\"p-[1em]\" {...rest}>\n {isEditing ? (\n <div\n ref={editRef}\n contentEditable\n onBlur={saveChanges}\n data-slot=\"summaryText\"\n className=\"p-2 min-h-[100px] whitespace-pre-wrap\"\n suppressContentEditableWarning={true}\n style={{\n whiteSpace: 'pre-wrap',\n wordWrap: 'break-word',\n }}\n />\n ) : (\n <div\n onClick={startEditing}\n data-slot=\"summaryText\"\n style={{\n whiteSpace: 'pre-wrap',\n wordWrap: 'break-word',\n }}\n >\n <Markdown options={{ overrides: markdownStyles }}>{allData.summaryText}</Markdown>\n </div>\n )}\n </div>\n );\n}\n\nexport function renderButton(props: any): JSX.Element {\n const { isEditable = false, gjsModel, performInteraction = () => {} } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const {\n text,\n icon,\n className,\n payload,\n variant = 'default',\n size = 'sm',\n affectedComponents,\n } = allData;\n\n function interact() {\n const id = gjsModel.get('id');\n performInteraction({\n id,\n interactionType: 'button',\n affectedComponents: getAffectedComponentsWithLoader([id, ...affectedComponents], true),\n payload,\n });\n }\n\n return (\n <Button\n className={className}\n onClick={!isEditable ? interact : () => {}}\n disabled={attributes.interactionApiInProgress}\n variant={variant}\n size={size}\n contentEditable={isEditable}\n >\n {attributes.interactionApiInProgress ? <Loader2Icon className=\"animate-spin\" /> : text}\n </Button>\n );\n}\n\nexport function getRenderers(): Record<string, (props: any) => JSX.Element> {\n return {\n ActionCard: renderActionCard,\n Card: renderCard,\n Chart: renderChart,\n Markdown: renderMarkdown,\n Table: renderTable,\n Tabs: renderTab,\n Button: renderButton,\n };\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"render-components.js","names":["chroma","React","useEffect","useState","useRef","theme","Markdown","Loader2Icon","Card","CardHeader","CardTitle","CardDescription","CardContent","CardFooter","ChartContainer","ChartTooltip","ChartTooltipContent","PieChart","Pie","BarChart","Bar","LineChart","Line","XAxis","YAxis","ResponsiveContainer","CartesianGrid","Legend","Table","TableHeader","TableRow","TableHead","TableBody","TableCell","cn","ScrollArea","ScrollBar","Tabs","TabsList","TabsTrigger","TabsContent","TableLoader","ChartLoader","CardLoader","Button","jsx","_jsx","jsxs","_jsxs","baseColors","colors","Blue_100","Blue_30","Purpley_100","Purpley_30","Light_Bluish_Green","Wild_Strawberry","getAffectedComponentsWithLoader","affectedComponents","showLoader","map","component","componentId","getNColors","n","_iterator","_createForOfIteratorHelperLoose","_step","done","baseColor","value","push","scale","mode","getOneColor","existing","color","base","Math","floor","random","length","selectedColorIndex","includes","selectedColors","i","renderActionCard","props","gjsModel","rest","_objectWithoutPropertiesLoose","_excluded","_useState","_extends","allData","setAllData","_allData$headerConten","headerContent","icon","_allData$bodyContent","bodyContent","_useState2","interactionApiInProgress","attributes","setAttributes","on","get","defaultClasses","className","isEditable","contentEditable","children","renderCard","_props$isEditable","_excluded2","_useState3","headerDescription","footerContent","footerClass","footerIcon","contentMetadata","contentMetadataClass","_useState4","defaultFooterClasses","defaultContentMetadataClasses","mergedCardClassName","mergedFooterClassName","mergedContentMetadataClassName","getCardContent","Fragment","style","renderChartComponent","chartType","data","config","cursor","content","hideLabel","dataKey","nameKey","innerRadius","strokeWidth","label","_ref","name","percent","toFixed","undefined","labelLine","dataKeys","chartUi","vertical","xAxis","align","wrapperStyle","marginLeft","_ref2","key","fill","radius","indicator","_ref3","type","stroke","_ref4","renderChart","_props$isEditable2","_props$performInterac","performInteraction","_excluded3","_useState5","_useState6","_allData$config","_allData$chartType","_allData$chartData","chartData","_allData$title","title","_allData$subTitle","subTitle","mergedClasses","width","totalDataPoints","barSize","barGap","barCategoryGap","interact","id","interactionType","height","orientation","TableButton","_useState7","loading","setLoading","onClick","_onClick","apply","arguments","_asyncToGenerator","_regeneratorRuntime","mark","_callee","wrap","_callee$","_context","prev","next","stop","disabled","isDisabled","variant","size","text","renderTable","_props$performInterac2","_excluded4","_useState8","_allData$data","_allData$headerMapper","headerMapper","_allData$isEditable","_allData$title2","_allData$subTitle2","_allData$actions","actions","_useState9","parsedData","datum","newData","takeRowAction","_x","_x2","_takeRowAction","_callee2","rowIndex","actionId","_callee2$","_context2","payload","row","tableId","headers","Object","keys","header","rows","values","renderActions","rowActions","action","renderTableComponent","head","idx","rIdx","cell","cIdx","tableData","renderTab","tabsWidth","tabs","defaultValue","tab","renderMarkdown","_excluded5","_useState10","_useState11","_useState12","isEditing","setIsEditing","editRef","startEditing","setTimeout","setupEditor","current","editor","innerHTML","textContent","summaryText","focus","saveChanges","innerText","markdownStyles","ul","h1","h2","h3","h4","h5","h6","options","overrides","ref","onBlur","suppressContentEditableWarning","whiteSpace","wordWrap","renderButton","_props$isEditable3","_props$performInterac3","_useState13","_useState14","_allData$variant","_allData$size","concat","getRenderers","ActionCard","Chart"],"sources":["../../../src/plugins/helpers/render-components.tsx"],"sourcesContent":["/* eslint-disable func-style */\n/* eslint-disable @typescript-eslint/no-empty-function */\n/* eslint-disable func-names */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport chroma from 'chroma-js';\nimport React, { useEffect, useState, JSX, useRef } from 'react';\n\nimport { theme } from '@peak-ai/ais-components/theme';\nimport Markdown from 'markdown-to-jsx';\nimport { Loader2Icon } from 'lucide-react';\n\nimport {\n Card,\n CardHeader,\n CardTitle,\n CardDescription,\n CardContent,\n CardFooter,\n} from '../../shadcn/components/ui/card';\nimport {\n ChartContainer,\n ChartTooltip,\n ChartTooltipContent,\n} from '../../shadcn/components/ui/chart';\n\nimport {\n PieChart,\n Pie,\n BarChart,\n Bar,\n LineChart,\n Line,\n XAxis,\n YAxis,\n ResponsiveContainer,\n CartesianGrid,\n Legend,\n} from 'recharts';\nimport {\n Table,\n TableHeader,\n TableRow,\n TableHead,\n TableBody,\n TableCell,\n} from '../../shadcn/components/ui/table';\nimport { cn } from '../../shadcn/utils';\nimport { ScrollArea, ScrollBar } from '../../shadcn/components/ui/scroll-area';\nimport { Tabs, TabsList, TabsTrigger, TabsContent } from '../../shadcn/components/ui/tabs';\nimport { TableLoader, ChartLoader, CardLoader } from '../../shadcn/components/ui/skeleton';\nimport { Button } from '../../shadcn/components/ui/button';\n\nconst baseColors = [\n [theme.colors.Blue_100, theme.colors.Blue_30],\n [theme.colors.Purpley_100, theme.colors.Purpley_30],\n [theme.colors.Light_Bluish_Green, '#06601b'],\n [theme.colors.Wild_Strawberry, '#4d001c'],\n];\n\nfunction getAffectedComponentsWithLoader(affectedComponents: Array<string>, showLoader = true) {\n return affectedComponents.map((component) => ({\n componentId: component,\n showLoader,\n }));\n}\n\nfunction getNColors(n: number) {\n const colors: Array<string[]> = [];\n\n for (const baseColor of baseColors) {\n // eslint-disable-next-line import/no-named-as-default-member\n colors.push(chroma.scale(baseColor).mode('lab').colors(n));\n }\n\n function getOneColor(existing: Array<string>) {\n let color: null | string = null;\n\n do {\n const base = colors[Math.floor(Math.random() * colors.length)];\n const selectedColorIndex = Math.floor(Math.random() * base.length);\n color = base[selectedColorIndex];\n } while (existing.includes(color));\n\n return color as string;\n }\n\n const selectedColors: Array<string> = [];\n\n for (let i = 0; i < n; i++) {\n selectedColors.push(getOneColor(selectedColors));\n }\n\n return selectedColors;\n}\n\n/* TODO: Loader remains */\nexport function renderActionCard(props: any): JSX.Element {\n const { gjsModel, ...rest } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const {\n headerContent = 'Default Action Card Title',\n icon,\n bodyContent = 'Default body content. Click to edit.',\n } = allData;\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const defaultClasses = 'bg-white text-black p-4 rounded-lg shadow border flex flex-col h-full';\n\n return (\n <Card className={defaultClasses} isEditable={false} contentEditable={false} {...rest}>\n <CardContent className=\"p-0\" isEditable={false} contentEditable={false}>\n <div className=\"px-4 py-3\">\n <div className=\"flex items-start\">\n <span className=\"text-5xl mr-2\" aria-hidden=\"true\">\n {icon}\n </span>\n <div className=\"flex-1\">\n <div className=\"text-xl font-semibold\">{headerContent}</div>\n <div className=\"text-base leading-relaxed mt-1\">{bodyContent}</div>\n </div>\n </div>\n </div>\n </CardContent>\n </Card>\n );\n}\n\nexport function renderCard(props: any): JSX.Element {\n const { isEditable = false, gjsModel, ...rest } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const {\n headerContent,\n headerDescription,\n bodyContent,\n footerContent,\n footerClass,\n footerIcon,\n contentMetadata,\n contentMetadataClass,\n className,\n } = allData;\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const defaultClasses = 'bg-white text-black p-4 rounded-lg shadow border flex flex-col h-full';\n const defaultFooterClasses = 'text-sm';\n const defaultContentMetadataClasses = 'text-xs';\n const mergedCardClassName = className ? cn(defaultClasses, className) : defaultClasses;\n const mergedFooterClassName = footerClass\n ? cn(defaultFooterClasses, footerClass)\n : defaultFooterClasses;\n const mergedContentMetadataClassName = contentMetadataClass\n ? cn(defaultContentMetadataClasses, contentMetadataClass)\n : defaultContentMetadataClasses;\n\n function getCardContent() {\n if (attributes.interactionApiInProgress) {\n return (\n <CardContent>\n <CardLoader />\n </CardContent>\n );\n }\n\n return (\n <React.Fragment>\n <CardHeader>\n <CardTitle data-slot=\"headerContent\" contentEditable={isEditable} className=\"text-lg\">\n {headerContent}\n </CardTitle>\n <CardDescription\n data-slot=\"headerDescription\"\n contentEditable={isEditable}\n className=\"text-sm\"\n >\n {headerDescription}\n </CardDescription>\n </CardHeader>\n\n <CardContent data-slot=\"bodyContent\" contentEditable={false} className=\"flex-grow\">\n <div className=\"text-3xl font-semibold truncate\">{bodyContent}</div>\n {contentMetadata && (\n <div className={mergedContentMetadataClassName} style={{ color: '#2A44D4' }}>\n {contentMetadata}\n </div>\n )}\n </CardContent>\n\n <CardFooter\n data-slot=\"footerContent\"\n contentEditable={isEditable}\n className={cn(mergedFooterClassName)}\n >\n {footerIcon && (\n <span className=\"mr-2\" aria-hidden=\"true\">\n {footerIcon}\n </span>\n )}\n {footerContent}\n </CardFooter>\n </React.Fragment>\n );\n }\n\n return (\n <Card {...rest} className={mergedCardClassName}>\n {getCardContent()}\n </Card>\n );\n}\n\nfunction renderChartComponent(chartType: string, data: any, config: any): JSX.Element {\n switch (chartType) {\n case 'pie':\n return (\n <PieChart>\n {data.length >= 20 && (\n <ChartTooltip cursor={false} content={<ChartTooltipContent hideLabel />} />\n )}\n <Pie\n data={data}\n dataKey={config.dataKey}\n nameKey={config.nameKey}\n innerRadius={60}\n strokeWidth={10}\n label={\n data.length < 20\n ? ({ name, percent }) => `${name}: ${(percent * 100).toFixed(0)}%`\n : undefined\n }\n labelLine={false}\n />\n </PieChart>\n );\n case 'bar':\n config.dataKeys = config.dataKeys || [];\n\n return (\n <BarChart data={data} {...config.chartUi}>\n <CartesianGrid vertical={false} />\n <XAxis dataKey={config.xAxis} />\n <YAxis />\n <Legend align=\"left\" wrapperStyle={{ marginLeft: 20 }} />\n {config.dataKeys.map(\n ({ key, name, color }: { key: string; name: string; color: string }) => {\n return (\n <Bar dataKey={key} fill={color ?? '#4caf50'} name={name} key={key} radius={2} />\n );\n },\n )}\n <ChartTooltip cursor={false} content={<ChartTooltipContent indicator=\"dashed\" />} />\n </BarChart>\n );\n case 'line':\n config.dataKeys = config.dataKeys || [];\n\n return (\n <LineChart data={data}>\n <CartesianGrid vertical={false} />\n <XAxis dataKey={config.xAxis} />\n <YAxis />\n <ChartTooltip cursor={false} content={<ChartTooltipContent indicator=\"dashed\" />} />\n {config.dataKeys.map(\n ({ key, name, color }: { key: string; name: string; color: string }) => {\n return (\n <Line\n type=\"monotone\"\n dataKey={key}\n stroke={color ?? '#4caf50'}\n name={name}\n key={key}\n />\n );\n },\n )}\n <Legend align=\"left\" />\n </LineChart>\n );\n default:\n return (\n <PieChart>\n {data.length >= 20 && (\n <ChartTooltip cursor={false} content={<ChartTooltipContent hideLabel />} />\n )}\n <Pie\n data={data}\n dataKey={config.dataKey}\n nameKey={config.nameKey}\n innerRadius={60}\n strokeWidth={10}\n label={\n data.length < 20\n ? ({ name, percent }) => `${name}: ${(percent * 100).toFixed(0)}%`\n : undefined\n }\n labelLine={false}\n />\n </PieChart>\n );\n }\n}\n\nexport function renderChart(props: any): JSX.Element {\n const { isEditable = false, gjsModel, performInteraction = () => {}, ...rest } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const {\n config = {},\n chartType = 'pie',\n chartData = [],\n className,\n title = 'Title',\n subTitle = 'Subtitle',\n } = allData;\n\n const defaultClasses = 'aspect-auto h-[250px] w-full';\n const mergedClasses = className ? cn(defaultClasses, className) : defaultClasses;\n\n if (chartType === 'pie') {\n const colors = getNColors(chartData.length);\n\n for (let i = 0; i < chartData.length; i++) {\n const data = chartData[i];\n\n if (!data.fill) {\n data.fill = colors[i];\n }\n }\n } else if (!config.color) {\n config.color = baseColors[Math.floor(Math.random() * baseColors.length)];\n }\n\n let width: number | undefined = undefined;\n\n if (chartType === 'bar') {\n const totalDataPoints = chartData.length * config.dataKeys.length;\n config.chartUi = {};\n\n if (totalDataPoints > 15) {\n width =\n totalDataPoints * 15 +\n config.dataKeys.length * 3 * chartData.length +\n chartData.length * 10;\n config.chartUi = {\n barSize: 15,\n barGap: 3,\n barCategoryGap: 0.5,\n width,\n };\n }\n }\n\n function interact() {\n const id = gjsModel.get('id');\n performInteraction({\n id,\n interactionType: 'button',\n chartData,\n affectedComponents: getAffectedComponentsWithLoader([id], true),\n type: 'chart',\n });\n }\n\n const chartUi = attributes.interactionApiInProgress ? (\n <ChartLoader />\n ) : (\n <React.Fragment>\n {chartType === 'bar' && config.chartUi ? (\n <ResponsiveContainer width=\"95%\" height={250}>\n <ScrollArea>\n <div className={width ? `min-w-[${width}px] w-full` : 'w-full'}>\n <ChartContainer {...rest} config={config} className={mergedClasses}>\n {renderChartComponent(chartType, chartData, config)}\n </ChartContainer>\n </div>\n <ScrollBar orientation=\"horizontal\" />\n </ScrollArea>\n </ResponsiveContainer>\n ) : (\n <ResponsiveContainer width=\"95%\" height={250}>\n <ChartContainer {...rest} config={config} className={mergedClasses}>\n {renderChartComponent(chartType, chartData, config)}\n </ChartContainer>\n </ResponsiveContainer>\n )}\n </React.Fragment>\n );\n\n return (\n <Card className=\"shadow border mt-2 mb-2\">\n <CardHeader>\n <CardTitle data-slot=\"title\" contentEditable={isEditable} className=\"text-2xl\">\n {title}\n </CardTitle>\n <CardDescription data-slot=\"subTitle\" contentEditable={isEditable} className=\"text-sm\">\n {subTitle}\n </CardDescription>\n </CardHeader>\n <CardContent data-slot=\"bodyContent\" contentEditable={false} className=\"px-6\">\n {chartUi}\n </CardContent>\n </Card>\n );\n}\n\n// Creating this separate component to manage loading state easily!\nfunction TableButton(props: any) {\n const [loading, setLoading] = useState(false);\n\n async function onClick() {\n setLoading(true);\n await props.onClick();\n setLoading(false);\n }\n\n const defaultClasses = 'mr-2';\n const mergedClasses = props.className ? cn(defaultClasses, props.className) : defaultClasses;\n\n return (\n <Button\n className={mergedClasses}\n onClick={!props.isEditable ? onClick : () => {}}\n disabled={props.isDisabled || loading}\n variant={props.variant}\n size=\"sm\"\n >\n {loading ? <Loader2Icon className=\"animate-spin\" /> : props.text}\n </Button>\n );\n}\n\nexport function renderTable(props: any): JSX.Element {\n const { gjsModel, performInteraction = () => {}, ...rest } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const {\n data = [],\n headerMapper = {},\n className,\n isEditable = false,\n title = 'Title',\n subTitle = 'Subtitle',\n actions = [],\n } = allData;\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const parsedData = data.map((datum: any) => {\n const newData = {\n ...datum,\n };\n\n delete newData.id;\n\n return newData;\n });\n\n async function takeRowAction(rowIndex: number, actionId: string) {\n const id = gjsModel.get('id');\n\n await performInteraction({\n id: actionId,\n interactionType: 'tableButton',\n payload: {\n row: data[rowIndex],\n tableId: id,\n },\n affectedComponents: [],\n });\n }\n\n const headers = Object.keys(parsedData[0] || {}).map((header) => headerMapper[header] || header);\n\n if (actions.length > 0) {\n headers.push('');\n }\n\n const rows = parsedData.map((datum: any) => Object.values(datum));\n\n const defaultClasses = 'aspect-auto h-[250px] w-full';\n const mergedClasses = className ? cn(defaultClasses, className) : defaultClasses;\n\n function renderActions(rowIndex: number, rowActions: Array<Record<string, any>>) {\n if (!actions.length) {\n return null;\n }\n\n return (\n <TableCell>\n {rowActions.map((action) => {\n return (\n <TableButton\n className={action.className}\n isEditable={isEditable}\n onClick={() => takeRowAction(rowIndex, action.id)}\n variant={action.variant}\n key={action.id}\n text={action.text}\n />\n );\n })}\n </TableCell>\n );\n }\n\n const renderTableComponent = attributes.interactionApiInProgress ? (\n <TableLoader />\n ) : (\n <Table {...rest} className={`caption-bottom text-sm ${mergedClasses}`} data-slot=\"table\">\n <TableHeader data-slot=\"table-header\" className=\"sticky top-0\">\n <TableRow>\n {headers.map((head: string, idx: number) => (\n <TableHead key={idx} data-slot={`table-header-${idx}`} contentEditable={isEditable}>\n {head}\n </TableHead>\n ))}\n </TableRow>\n </TableHeader>\n <TableBody data-slot=\"table-body\">\n {rows.map((row: any[], rIdx: number) => (\n <TableRow\n key={rIdx}\n data-slot={`row-${rIdx}`}\n className=\"hover:bg-muted/50 border-b transition-colors\"\n >\n {row.map((cell: string, cIdx: number) => (\n <TableCell\n key={cIdx}\n data-slot={`cell-${rIdx}-${cIdx}`}\n className=\"p-2 align-middle whitespace-nowrap\"\n contentEditable={false}\n >\n {cell}\n </TableCell>\n ))}\n {renderActions(rIdx, actions)}\n </TableRow>\n ))}\n </TableBody>\n </Table>\n );\n\n const tableData = (\n <ScrollArea data-slot=\"table-container\" className={mergedClasses}>\n {renderTableComponent}\n <ScrollBar orientation=\"horizontal\" />\n </ScrollArea>\n );\n\n return (\n <Card className=\"shadow border\">\n <CardHeader>\n <CardTitle data-slot=\"title\" contentEditable={isEditable} className=\"text-2xl\">\n {title}\n </CardTitle>\n <CardDescription data-slot=\"subTitle\" contentEditable={isEditable} className=\"text-sm\">\n {subTitle}\n </CardDescription>\n </CardHeader>\n <CardContent data-slot=\"bodyContent\" contentEditable={false}>\n {tableData}\n </CardContent>\n </Card>\n );\n}\n\nexport function renderTab(props: any): JSX.Element {\n let tabsWidth = 200;\n\n if (props.tabs.length > 4) {\n tabsWidth = 150;\n }\n\n return (\n <Tabs defaultValue={props.defaultValue}>\n <div className=\"text-center mb-4\">\n <TabsList className=\"bg-gray-300\">\n {props.tabs.map((tab: string) => (\n <TabsTrigger value={tab} key={tab} className={`text-md w-[${tabsWidth}px]`}>\n {tab}\n </TabsTrigger>\n ))}\n </TabsList>\n </div>\n {props.tabs.map((tab: string) => (\n <TabsContent value={tab} className=\"tabs-content\" key={tab} />\n ))}\n </Tabs>\n );\n}\n\nexport function renderMarkdown(props: any): JSX.Element {\n const { gjsModel, ...rest } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const [isEditing, setIsEditing] = useState(false);\n const editRef = useRef<HTMLDivElement>(null);\n\n const startEditing = () => {\n setIsEditing(true);\n setTimeout(() => {\n setupEditor();\n }, 0);\n };\n\n const setupEditor = () => {\n if (!editRef.current) {\n return;\n }\n\n const editor = editRef.current;\n editor.innerHTML = '';\n editor.textContent = allData.summaryText;\n editor.focus();\n };\n\n // Save changes and exit editing mode\n const saveChanges = () => {\n if (!editRef.current) {\n return;\n }\n\n const content = editRef.current.innerText || '';\n setAllData((prev: Record<string, any>) => ({\n ...prev,\n summaryText: content,\n }));\n setIsEditing(false);\n editRef.current.innerHTML = '';\n };\n\n const markdownStyles = {\n ul: { props: { className: 'list-disc' } },\n h1: { props: { className: 'text-4xl font-bold leading-[4rem]' } },\n h2: { props: { className: 'text-3xl font-bold leading-[3rem]' } },\n h3: { props: { className: 'text-2xl font-bold leading-[2rem]' } },\n h4: { props: { className: 'text-xl font-bold leading-[2.5rem]' } },\n h5: { props: { className: 'text-lg font-bold leading-[2.5rem]' } },\n h6: { props: { className: 'text-base font-bold leading-[2rem]' } },\n };\n\n if (!allData.isEditable) {\n return (\n <div className=\"px-[1em]\" {...rest}>\n <div data-slot=\"summaryText\">\n <Markdown options={{ overrides: markdownStyles }}>{allData.summaryText}</Markdown>\n </div>\n </div>\n );\n }\n\n return (\n <div className=\"p-[1em]\" {...rest}>\n {isEditing ? (\n <div\n ref={editRef}\n contentEditable\n onBlur={saveChanges}\n data-slot=\"summaryText\"\n className=\"p-2 min-h-[100px] whitespace-pre-wrap\"\n suppressContentEditableWarning={true}\n style={{\n whiteSpace: 'pre-wrap',\n wordWrap: 'break-word',\n }}\n />\n ) : (\n <div\n onClick={startEditing}\n data-slot=\"summaryText\"\n style={{\n whiteSpace: 'pre-wrap',\n wordWrap: 'break-word',\n }}\n >\n <Markdown options={{ overrides: markdownStyles }}>{allData.summaryText}</Markdown>\n </div>\n )}\n </div>\n );\n}\n\nexport function renderButton(props: any): JSX.Element {\n const { isEditable = false, gjsModel, performInteraction = () => {} } = props;\n\n const [allData, setAllData] = useState({\n ...props,\n });\n\n const [attributes, setAttributes] = useState({\n interactionApiInProgress: false,\n });\n\n useEffect(() => {\n gjsModel.on('change:componentProps', () => {\n setAllData({\n ...gjsModel.get('componentProps'),\n });\n });\n }, []);\n\n useEffect(() => {\n gjsModel.on('change:attributes', () => {\n setAttributes({\n ...gjsModel.get('attributes'),\n });\n });\n }, []);\n\n const {\n text,\n icon,\n className,\n payload,\n variant = 'default',\n size = 'sm',\n affectedComponents,\n } = allData;\n\n function interact() {\n const id = gjsModel.get('id');\n performInteraction({\n id,\n interactionType: 'button',\n affectedComponents: getAffectedComponentsWithLoader([id, ...affectedComponents], true),\n payload,\n });\n }\n\n return (\n <Button\n className={className}\n onClick={!isEditable ? interact : () => {}}\n disabled={attributes.interactionApiInProgress}\n variant={variant}\n size={size}\n contentEditable={isEditable}\n >\n {attributes.interactionApiInProgress ? <Loader2Icon className=\"animate-spin\" /> : text}\n </Button>\n );\n}\n\nexport function getRenderers(): Record<string, (props: any) => JSX.Element> {\n return {\n ActionCard: renderActionCard,\n Card: renderCard,\n Chart: renderChart,\n Markdown: renderMarkdown,\n Table: renderTable,\n Tabs: renderTab,\n Button: renderButton,\n };\n}\n"],"mappings":"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","ignoreList":[]}
|